正则表达式

今天刚拿出代码之美好好观赏一下,第一篇就让我眼前一亮,竟然是介绍关于正则表达式的,之前自己也自学过一段这个,但是那时候可能是自己还没有到这个水平吧,看了挺久的,越看越晕 ,感觉是正则表达式真的不是人用的啊!!!于是就没有然后了~


今天看到几十年前的一位计算机大师Rob Pike因为想让正则表达式的使用更加方便一点,而不是需要各种巨大的package,就自己当场手撸了30行左右的C代码,就解决了95%正则表达式的内容。但是就觉得相见恨晚啊,必须的好好学习一下。下面是代码。

/* match: search for regexp anywhere in text */
int match(char *regexp, char *text)
{
    if (regexp[0] == '^')
        return matchhere(regexp+1, text);
do { /* must look even if string is empty */
    if (matchhere(regexp, text))
        return 1;
} while (*text++ != '\0');
return 0;
}
/* matchhere: search for regexp at beginning of text */
int matchhere(char *regexp, char *text)
{
    if (regexp[0] == '\0')
        return 1;
    if (regexp[1] == '*')
        return matchstar(regexp[0], regexp+2, text);
    if (regexp[0] == '$' && regexp[1] == '\0')
        return *text == '\0';
    if (*text!='\0' && (regexp[0]=='.' || regexp[0]==*text))
        return matchhere(regexp+1, text+1);
    return 0;
}
/* matchstar: search for c*regexp at beginning of text */
int matchstar(int c, char *regexp, char *text)
{
do { /* a * matches zero or more instances */
    if (matchhere(regexp, text))
        return 1;
} while (*text != '\0' && (*text++ == c || c == '.'));
return 0;
}

这是基本的搜索规则:

Character Meaning
c Matches any literal character c .
. (period) Matches any single character.
^ Matches the beginning of the input string.
$ Matches the end of the input string.
* Matches zero or more occurrences of the previous character.

只能说是致敬大师了,一个程序充分体现了C语言指针的力量和递归的魅力~

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 推荐几个正则表达式编辑器 Debuggex :https://www.debuggex.com/ PyRegex:...
    木易林1阅读 11,613评论 9 151
  • 几个正则表达式编辑器 Debuggex :https://www.debuggex.com/ PyRegex:ht...
    没技术的BUG开发攻城狮阅读 4,626评论 0 23
  • 正则表达式到底是什么东西?字符是计算机软件处理文字时最基本的单位,可能是字母,数字,标点符号,空格,换行符,汉字等...
    狮子挽歌阅读 2,193评论 0 9
  • 初衷:看了很多视频、文章,最后却通通忘记了,别人的知识依旧是别人的,自己却什么都没获得。此系列文章旨在加深自己的印...
    DCbryant阅读 4,099评论 0 20
  • 注:本篇文章只为方便查看,特此保留,如有冒犯,敬请谅解!!! 本文目标 30分钟内让你明白正则表达式是什么,并对它...
    阿杰Alex阅读 1,516评论 0 10