加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

构建基于正则表达式的解析器

发布时间:2020-12-14 06:32:08 所属栏目:百科 来源:网络整理
导读:构建基于正则表达式的解析器是愚蠢的吗? 使用现代模式匹配嵌套的parens非常简单.不计算空白,这种事情: ( (?: [^()] *+ | (?0) )* ) 适用于主流语言,如Perl和PHP,以及任何使用PCRE的东西. 但是,你真的需要完整解析的语法正则表达式,否则你会疯了.不要使用
构建基于正则表达式的解析器是愚蠢的吗?
使用现代模式匹配嵌套的parens非常简单.不计算空白,这种事情:
( (?: [^()] *+ | (?0) )* )

适用于主流语言,如Perl和PHP,以及任何使用PCRE的东西.

但是,你真的需要完整解析的语法正则表达式,否则你会疯了.不要使用其正则表达式不支持将正则表达式分解为较小单元的语言,或者不支持正确调试其编译和执行的语言.生活对于低级别的hackery来说太短暂了.如果你打算这样做,也可以回到汇编语言.

我写了很多关于递归模式,语法模式和解析的内容:例如,参见here for parsing approaches和here for lexer approaches;还有,final solution here.

此外,Perl的Regexp::Grammars module在将语法正则表达式转换为解析结构时特别有用.

所以,无论如何,去吧.你会从中学到很多东西.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读