免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: hibernator
打印 上一主题 下一主题

如何解析C源文件 [复制链接]

论坛徽章:
0
11 [报告]
发表于 2007-08-02 15:50 |只看该作者
先 分词, 再解析成树. 就是这样了.

主要你要解析到什么程序. 作什么用?

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
12 [报告]
发表于 2007-08-02 18:08 |只看该作者
原帖由 Mart1n 于 2007-8-2 15:47 发表
根据你的需求,自己写一个语法分析程序即可。也就几百行就搞定了。

你说的怕只是词法分析器,这个手写还成。

论坛徽章:
0
13 [报告]
发表于 2007-08-02 19:16 |只看该作者
原帖由 Mart1n 于 2007-8-2 15:47 发表
根据你的需求,自己写一个语法分析程序即可。也就几百行就搞定了。


如何写, 请说详细点.

最近看了看vim的语法高亮, 是用的模式匹配实现的,大概确实也就几百行.

论坛徽章:
0
14 [报告]
发表于 2007-08-02 21:30 |只看该作者
yard spirit

论坛徽章:
0
15 [报告]
发表于 2007-08-05 02:53 |只看该作者
原帖由 hibernator 于 2007-8-2 19:16 发表


如何写, 请说详细点.

最近看了看vim的语法高亮, 是用的模式匹配实现的,大概确实也就几百行.

有限的关键字语法高亮只要词法分析器就够了,但如果要支持重定义、自定义和成员列表等,则涉及到语义分析,最好还是要借助于bison/yacc一类的工具

论坛徽章:
0
16 [报告]
发表于 2007-08-05 23:31 |只看该作者
多工具集成!这只是我的一个建议 你把多个工具集合起来!

论坛徽章:
0
17 [报告]
发表于 2007-08-05 23:34 |只看该作者
根据你的需求,自己写一个语法分析程序即可。也就几百行就搞定了.

词法加语法 你几百行内 搞定给我看看

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
18 [报告]
发表于 2007-08-05 23:35 |只看该作者
原帖由 benjiam 于 2007-8-5 23:34 发表
根据你的需求,自己写一个语法分析程序即可。也就几百行就搞定了.

词法加语法 你几百行内 搞定给我看看

也许人家说的不是几百行 C 代码?
几百行 lex/yacc 足够了。
再或者几百行 Perl 程序也差不多吧。

论坛徽章:
0
19 [报告]
发表于 2007-08-06 12:16 |只看该作者
原帖由 hibernator 于 2007-8-1 12:38 发表
3楼,
我的最初目的是解析数据结构,比如一个结构体,能解析出它内部的成员及类型,支持递归。可能还将有扩展,需要解析函数和宏。

...


to MMMIX,这个需求(不包含可能的扩展),几百行C确实够了。
对于结构体,如果不是太复杂的定义,包含词(类型,变量名等)和符号({};等),那么这个语法分析应该在一百行左右,抄个经典的lex改改。
语法没有控制流等,也不需要跟踪所有的变量,也不需要优化编译。只分析几个语法成份即可。

如果还需要扩展,分析函数和宏,代码就多了。

yacc, lex等确实是好工具,随需而变嘛~~
我本科论文的一部分是三维模型文件的词法和语法分析,自己写的,也不过就几百行代码,包括了很多类型定义和语法结构。

to 楼主,分析程序就不详细解释,大家科班出身都上过这个课。
楼主可能想自己实践,那就写写看吧,程序这东西嘛就是想起来复杂写起来简单。

[ 本帖最后由 Mart1n 于 2007-8-6 12:35 编辑 ]

论坛徽章:
0
20 [报告]
发表于 2007-08-08 14:32 |只看该作者
原帖由 Mart1n 于 2007-8-6 12:16 发表


to MMMIX,这个需求(不包含可能的扩展),几百行C确实够了。
对于结构体,如果不是太复杂的定义,包含词(类型,变量名等)和符号({};等),那么这个语法分析应该在一百行左右,抄个经典的lex改改。
语法没有 ...


编译原理课也就用yacc和lex写过四则混合运算的解析,没到解析文件那么复杂。几百行C程序也大概就能去掉注释和字符串,解析数据结构远远做不了。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP