C/C++中的字符串恍惚匹配
需求:
准入授权设置文件有时候分了好几个维度举办设置,譬喻 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 <iostream>
#include <fnmatch.h>
#include <vector>
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<char *> 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) <<"]"<<endl;
}
}
++z;
}
}
功效:
尝试一把,功效还不赖,完全满意需求:
需求满意了,我担忧的尚有一个问题,那就是机能,注释掉cout输出,将while z语句调至1,000,000,从头编译跑一下:
time ./fnmatch
看来效率还不错,2.1s 举办了100W次匹配,平均2us一次,机能要求也满意了…