编译原理实验二(1)——前期准备
注:
课程:《编译技术》上机
实验二:符号表管理与语义检查。对抽象语法树进行遍历,完成符号表的管理与相关属性计算。通过对符号表的管理实现语义分析。
此处完成 实验前期准备
简单说两句:
因为编译原理实验的分数跟计组比起来少太多了,搞得好跟搞得不好最后的分差几乎没有。所以经过考虑,我最终还是决定将时间投入复习中,实验二只搞出一个最基础的东西来就好。
前期准备
- 已经将整个文件夹都备好份,以供魔改后的回溯
开始实验
第一步
修改ast.c文件
- 打开实验教程文档,附录五
将附录五代码复制粘贴到ast.c的后面,注意一下,那个#include,#define DEBUG移到代码最开头去
-
第200行,添加全局变量LEV
LEV是 层数,但是他没有定义,之后编译时会报错,这里给他补充上
-
第945,946行注释掉
这两行是用来生成中间代码,目标代码的,我们这里只搞实验二,为了避免这两个代码里的bug干扰,我们将他注释掉。
第二步
修改parser.y文件(parser.y是C语言文法)
- 第60行修改program语法
将我们之前删掉的semantic_Analysis0($1);加上
结果检验
依次运行
flex lex.l
bison -d parser.y
gcc -o parser lex.yy.c parser.tab.c ast.c
parser test.c
发现有乱码,使用chcp 65001切换到UTF-8编码界面
发现符号表输出成功。
这篇主要是讲一下,生成符号表的具体操作步骤,下面一篇会补充一些代码,然后讲一下怎么进行语义效验
写在结尾
希望以上可以帮到你!
如有错误,或不同想法,欢迎指出,互相学习共同进步!
Share this content:
发表评论