编译原理结构框架7语义分析与中间代码生成

7  语义分析与中间代码生成



重点:三地址码,各种语句的目标代码结构、 语法制导定义与翻译模式。

难点:布尔表达式的翻译,对各种语句的目标

        代码结构、语法制导定义与翻译模式的

        理解。

7.1 中间代码的形式

抽象语法树、逆波兰式、三地址码(三元式、四元式)、DAG图表示


7.2 声明语句的翻译

n mktable (previous) :创建一个新的符号表 ,previous 指外围符号表;
n enter(table,name, type, offset) :在 table 指向的符号表中为名字 name 建立一个新表项
n addwidth (table,width) :将符号表 table 的所有表项的宽度之和存储于表头;
n enterproc (table,name, newtable ) :在 table 指向的符号表中为过程 name 建立一个新表项, newtable 指向过程 name 的符号表;

7.3 赋值语句的翻译
n gencode (code) :产生一条中间代码
n newtemp :产生新的临时变量
n lookup :检查符号表中是否出现某名字

7.4类型检查

7.5控制语句的翻译


7.6 回填

    1makelist(i)创建一个只包含i的新表,i 

         是四元式数组的一个索引(下标),或者说

          i是四元式代码序列的一个标号。

    2merge(p1, p2)合并由指针p1p2指向

         的两个表并且返回一个指向合并后的表的

         指针。

    3backpatch(pi)i作为目标标号回填到

          p所指向的表中的每一个转移指令中去。

此处的“表”都是为“回填”所准备的链表


7.7 switch语句的翻译


switchE

  begin

  case V1: S1

  case V2: S2

  . . .

  case Vn- 1: Sn– 1

  default: Sn

  end

E的代码

         ifE.addr¹ V1 gotoL1  

           S1的代码 

         gotoS.nextlist 

L1:    if E.addr¹V2gotoL

         S2的代码

         gotoS.nextlist

L2    . . .

     . . .

Ln-2  if E.addr¹Vn-1gotoLn-1

            Sn-1的代码

            gotoS.nextlist

Ln-1  Sn的代码

S.nextlist :


7.8  过程调用和返回语句的翻译

S => call id (Elist)

Elist => Elist,E

Elist => E

S => return E


过程调用id(E1, E2, …, En)的中间代码结构

E1.addr := E1的代码

E2.addr := E2的代码

  .. .

En.addr:= En的代码

param E1.addr

param E2.addr

  . . .

paramEn.addr

call id.addr,n


7.9 输入输出语句的翻译


测试:


试将下面的语句翻译成四元式序列

while(a < c) ∧ (b < d) do

   if a = 1 then

       c = c + 1

   else

       while a <= d do

             a = a + 2

解析:

100: if ( a < c ) goto 102

101: goto 114

102: if ( b < d ) goto 104

103: goto 114

104: if ( a == 1 ) goto 106

105: goto 109

106: t1 := c + 1

107: c := t1

108: goto 100

109: if ( a <= d ) goto 111

110: goto 100

111: t2 := a + 2

112: a = t2

113: goto 109

114:


  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
⒈ 题目 分析对象的BNF定义如下: 〈算术表达式〉∷=〈项〉|〈算术表达式〉+〈项〉|〈算术表达式〉-〈项〉 〈项〉∷=〈因式〉|〈项〉*〈因式〉|〈项〉/〈因式〉 〈因式〉∷=〈变量〉│(〈算术表达式〉) 〈变量〉∷=〈字母〉 〈字母〉∷=A|B|C|D|E|F|G|H|I|J|K|L|M|N|O|P|Q|R|S|T|U|V|W|X|Y|Z (a)总程序过程 (b) ( E过程)算术表达式处理 (c)项处理(T过程) (d)因式处理过程)(F过程) (e) (f) 图2-7-5 递归下降法分析表达式之框图 (a) ZC 过程;(b) E 过程;(c) T 过程; (d) F 过程;(e) 函数过程 SYM ;(f) 过程 ADVANCE ⒉ 算法 用递归下降法分析上述算术表达式的框图,如图2-7-5所示。这里,ZC过程为总控程序,主要完成: ⑴ 通知外界键入算术表达式; ⑵ 控制E过程分析算术表达式; ⑶ 根据分析结果之正误,分别通知外界不同的信息。 ZC过程被设计成可以分析无穷多个算术表达式。E、T和F三个过程分别对应〈算术表达式〉、〈项〉和〈因式〉三个产生式的处理。它们用到两个公共过程。一个是函数过程SYM,它负责从输入字符串ST中取出下一个字符,并存入SYM中等待分析。另一个过程ADVANCE负责剔除ST中的首字符。 算法的书写和实现也请参考课堂教学所给出的方法和实例,不一定照搬以上的框图。 ⒋ 小结 ⑴ 实习前的准备 按实习目的和要求,用PASCAL语言编写一个语法分析程序,同时考虑相应的数据结构。 ⑵ 调试 调试例子应包括符合语法规则的算术表达式,以及分析程序能够判别的若干错例。 ⑶ 输出 对于所输入的算术表达式,不论对错,都应有明确的信息告诉外界。 ⑷编写上机实习报告。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值