编译原理(七)中间代码生成

时间:2022-12-08 03:56:30

我们以一个排序来演示中间代码生成编译原理(七)中间代码生成

语义动作用到的函数

mkTable(previous):创建符号表,参数为过程id

enter(table,name,type,offset):进入符号表,四个参数分别为:表名,参数名称,参数类型,下标

addWidth(table,width):增加符号表容量,参数为:哪一个符号表,增加多少容量

enterProc(table,name,newtable):进入一个过程,三个参数分别为:从哪个符号表进入,过程名称,过程中的符号表


赋值语句:

编译原理(七)中间代码生成

上面方法中,lookup:是查找过程对应符号表,emit:做赋值运算

还有其他运算,例如数组查找,布尔表达式,条件判断等,在此就不一一列举了。