编译原理实验二(1)——前期准备

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


此处完成 实验前期准备

简单说两句:
  因为编译原理实验的分数跟计组比起来少太多了,所以经过仔细考虑,我最终还是决定将时间投入复习中,实验二只搞出一个最基础的东西来就好。之后如果想要补充些东西的话,再说吧....

前期准备
  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编码界面
在这里插入图片描述

 发现符号表输出成功。

这篇主要是讲一下,生成符号表的具体操作步骤,下面一篇会补充一些代码,然后讲一下怎么进行语义效验

写在结尾

希望以上可以帮到你!
如有错误,或不同想法,欢迎指出,互相学习共同进步!

源码资源下载:点赞关注后即可免费下载,下载戳我!

如果不可以的话,戳这里百度网盘 提取码:hust

  • 4
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值