博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C/C++ 字符串模糊匹配
阅读量:7002 次
发布时间:2019-06-27

本文共 1731 字,大约阅读时间需要 5 分钟。

需求:

  准入授权配置文件有时候分了好几个维度进行配置,例如 company|product|sys这种格式的配置:

1.配置 "sina|weibo|pusher" 表示 sina公司weibo产品pusher系统能够准入,而"sina|weibo|sign"不允许准入

2.配置 "sina|*|pusher” 表示sina公司所有产品的pusher系统都能够准入

3.配置 “*|*|pusher” 表示所有公司的所有产品的pusher系统都能够准入

  …

  类似还有很多场景,好了,简单的东西不扯蛋了.

 

实现:

  面对这个需求我第一时间想的是如何设计模式串,如何快速实现功能,因为我现在写的是一个C服务,所以我首先出现在我脑海的是一大堆strchr(XXX, ‘*’), strchr(XXX, ‘|’)等等东西,后面发现这个东西没有必要自己造轮子,有现成的函数可以用,那就是fnmatch.

  google了一下,发现fnmatch的资料并不是很多,大部分还都是讲php函数的,所以没办法,只能自己写写测测了.

#include 
#include
#include
using namespace std;int main(){ const char* orgin_str = "sina|weibo|pusher"; char pattern_arr[][20] = { {"sina|*|pusher"}, {"sina|*|*"}, {"*|weibo|*"}, //不能被匹配的 {"sina|pic|*"}, {"*|*|sign"}, {"*|weibo|sign"}, {"*|pic|sign"}, {"sina|pic|sign"}, {"*|*|*"} }; static int pattern_arr_size = sizeof(pattern_arr) / sizeof(pattern_arr[0]); vector
vec_str; for(int i = 0; i < pattern_arr_size; i ++) { vec_str.push_back(pattern_arr[i]); } int ret; int z = 0; while(z < 1){ for(int i = 0; i < vec_str.size(); i++) { ret = fnmatch(vec_str.at(i), orgin_str, FNM_PATHNAME); if(FNM_NOMATCH == ret){ cout<<"sorry I'm failed ["<< vec_str.at(i) <<"]"<

 

结果:   

  实验一把,结果还不赖,完全满足需求:

  

  需求满足了,我担心的还有一个问题,那就是性能,注释掉cout输出,将while z语句调至1,000,000,重新编译跑一下:

  time ./fnmatch

看来效率还不错,2.1s 进行了100W次匹配,平均2us一次,性能要求也满足了...

 

参考文献: 

fnmatch源码实现:  http://www.opensource.apple.com/source/sudo/sudo-16/sudo/fnmatch.c

MAN:   http://linux.die.net/man/3/fnmatch

转载于:https://www.cnblogs.com/Creator/archive/2013/03/25/2981186.html

你可能感兴趣的文章
使用控制台启动Android设备模拟器
查看>>
subscription group permisson
查看>>
Flex实现页面跳转的功能可用性分析 .
查看>>
对HGE游戏引擎的一次封
查看>>
poj 2051 Argus
查看>>
div内快元素[div,p。。。]居中办法
查看>>
2017届高三(下)高考模拟(理科)数学试题(自己命题与写代码)
查看>>
swagger-editor
查看>>
Groovy与Java集成常见的坑(转)
查看>>
SpringMVC(转)
查看>>
__tostring用法,__call处理调用,__clone克隆对象
查看>>
PHP读取文件
查看>>
免费的区块链学习资料
查看>>
ILSVRC
查看>>
matlab超限像素平滑法_脉冲伏安法理论基础
查看>>
arduino 串口读取字符串_Arduino传感器教程 第24章NRF24L01 控制电舵机
查看>>
状态码202_HTTP状态码(HTTP Status Code)
查看>>
sharepoint 2010 网站集定期备份
查看>>
管理SCCM/MDT中的驱动分类
查看>>
java之HashTable
查看>>