编译原理复习7

语义分析和中间代码产生

中间语言

源语言程序 Compiler Front End 中间语言程序 Compiler Back End 目标语言程序

常用的中间语言

  • 后缀式,逆波兰表示
  • 图表示:DAG、抽象语法树
  • 三地址代码
    • 三元式
    • 四元式
    • 间接三元式

后缀式

Markdown

Markdown

Markdown

Markdown

Markdown

无循环有向图

Markdown

Markdown

Markdown

Markdown

三地址代码

  • 三地址代码

    x:=y op z

  • 三地址代码可以看成是抽象语法树或DAG的一种线性表示

Markdown

Markdown

Markdown

Markdown

Markdown

Markdown

Markdown

Markdown

赋值语句的翻译

直接赋值语句

i = 0;

翻译后:

i = 0

自己对自己赋值

i = i + 1;

翻译后:

t1 = i + 1
i = t1

布尔表达式的翻译

控制语句的翻译

一个if套一个条件

原语句

if(expr1) {
  statement1;
}
statement2;

翻译:

if (expr1) goto L1
goto L2
L1: statement1
L2: statement2

if-else

原语句

if(expr1) {
  statement1;
} else {
  statement2;
}
statement3;

翻译:

if(expr1) goto L1
goto L2
L1: statement1
goto L3
L2: statement2
L3: statement3

while套两个条件

原语句

while(expr1 && expr2) {
  statement1;
}
statement2;

翻译:

L0: if(expr1) goto L2
L1: goto L4
L2: if(expr2) goto L3
goto L1
L3: statement1
goto L0
L4: statement2

过程调用的处理

数组型

a[i1][i2]

翻译后:

首先我们假设:

  • a数组的起始位置是addrA
  • 每个数组元素所占大小为w
  • 数组是从 li1,li2 开始计数的,到 ui1,ui2 为止,我们私下将 ui2li2 算好,记做 n2
t1 = l1 * n2
t2 = t1 + l2
t3 = t2 * w
t4 = addrA - t3
########以上部分与下标均无关###############
t5 = i1 * n2
t6 = t5 + i2
t7 = t6 * w
t8 = t4[t7]

具体推导:

Addr(A[i1, i2])
=addrA+((i1-low1)*n2+i2-low2)*w
=(i1*n2+i2)*w+addrA-(low1*n2+low2)*w
=addrA-(low1*n2+low2)*w+(i1*n2+i2)
Where n2=upper2-low2+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语言编写一个语法分析程序,同时考虑相应的数据结构。 ⑵ 调试 调试例子应包括符合语法规则的算术表达式,以及分析程序能够判别的若干错例。 ⑶ 输出 对于所输入的算术表达式,不论对错,都应有明确的信息告诉外界。 ⑷编写上机实习报告。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值