Linux下自带的regex
Linux下可直接用regex.h来支持正则表达式。
Android同样也有该头文件,可认为Android也是支持的。
#include <sys/types.h>
#include <regex.h>
int regcomp(regex_t *preg, const char *regex, int cflags);
int regexec(const regex_t *preg, const char *string, size_t nmatch, regmatch_t pmatch[], int eflags);
size_t regerror(int errcode, const regex_t *preg, char *errbuf, size_t errbuf_size);
void regfree(regex_t *preg);
rm_so为匹配字符串起始偏移(start offset),rm_eo为匹配字符串的终止偏移(end offset)。
typedef struct {
regoff_t rm_so;
regoff_t rm_eo;
} regmatch_t;
1 #include <stdio.h> 2 #include <regex.h> 3 #include <string.h> 4 5 int main(void) 6 { 7 const char *str = "aabbccdd.com"; 8 const char *pattern = "^(.+?)\\.com$"; 9 regex_t reg; 10 regmatch_t match[10]; 11 12 int ret = 0; 13 ret = regcomp(®, pattern, REG_EXTENDED | REG_NEWLINE); 14 if(ret != 0) 15 printf("error\n"); 16 else 17 { 18 ret = regexec(®, str, 10, match, 0); 19 if(ret != REG_NOMATCH) 20 { 21 int len = match[1].rm_eo - match[1].rm_so; 22 char buf[1024] = {0}; 23 memcpy(buf, str + match[1].rm_so, len); 24 printf("final buf %s\n", buf); 25 } 26 } 27 regfree(®); 28 return 0; 29 }
regmatch_t数组用来存储匹配的结果,该参数为数组的原因实际上是为了匹配group,其规则和Java等实现一致,若匹配成功,数组的[0]为整个匹配串,即group(0),其他为各个匹配到的组。
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。