免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2170 | 回复: 5
打印 上一主题 下一主题

flex代码看不太懂,哪位大哥研究过 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-06-26 23:55 |只看该作者 |倒序浏览
小弟最近尝试着看看flex代码,姑且不论前面的,看到由正则表达式转为nfa时,都看不太懂,也就不谈后面长长的nfa转化为dfa。
有哪位大哥分析过flex的,能否给点帮助,谢谢。

论坛徽章:
3
2015年迎新春徽章
日期:2015-03-04 09:56:11数据库技术版块每日发帖之星
日期:2016-08-03 06:20:00数据库技术版块每日发帖之星
日期:2016-08-04 06:20:00
2 [报告]
发表于 2009-06-29 00:12 |只看该作者
先想清楚一个regex怎么构造等价的状态机
然后再去想如何把n个状态机拼在一起成为一个大的状态机的问题.
思考了这些理论问题,就明白LEX是怎么干了.
flex对于所有的regex是采用一个整体的大状态机来解决问题

论坛徽章:
0
3 [报告]
发表于 2009-06-30 00:02 |只看该作者

回复 #2 cjaizss 的帖子

多谢,不过手上只有龙书,不知道能不能想通

论坛徽章:
0
4 [报告]
发表于 2009-06-30 14:40 |只看该作者

回复 #3 lyl19 的帖子

RE -> Thompson's construction algorithm -> NFA -> subset construction algorithm -> DFA

论坛徽章:
0
5 [报告]
发表于 2009-06-30 21:46 |只看该作者
flex的代码不是bison描述的么?lz的自动机那里看见的?bison生成的C代码?

论坛徽章:
0
6 [报告]
发表于 2009-07-02 21:26 |只看该作者
确实是bison来解析的,当看到一个匹配式时,bison的action就会创建相应的状态机
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP