注:
课程:《编译技术》上机
实验二:符号表管理与语义检查。对抽象语法树进行遍历,完成符号表的管理与相关属性计算。通过对符号表的管理实现语义分析。

此处完成 实验前期准备

简单说两句:
  因为编译原理实验的分数跟计组比起来少太多了,搞得好跟搞得不好最后的分差几乎没有。所以经过考虑,我最终还是决定将时间投入复习中,实验二只搞出一个最基础的东西来就好。

前期准备
  1. 已经将整个文件夹都备好份,以供魔改后的回溯
开始实验
第一步

修改ast.c文件

  1. 打开实验教程文档,附录五

在这里插入图片描述
 将附录五代码复制粘贴到ast.c的后面,注意一下,那个#include,#define DEBUG移到代码最开头去
在这里插入图片描述
在这里插入图片描述

  1. 第200行,添加全局变量LEV
     LEV是 层数,但是他没有定义,之后编译时会报错,这里给他补充上
    在这里插入图片描述

  2. 第945,946行注释掉
     这两行是用来生成中间代码,目标代码的,我们这里只搞实验二,为了避免这两个代码里的bug干扰,我们将他注释掉。
    在这里插入图片描述

第二步

修改parser.y文件(parser.y是C语言文法)

  1. 第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: