《编译原理》控制流语句 if 和 while 语句的翻译 - 例题解析

将 if 和 while 语句翻译成四元式

注:不同教材会有小差异,使用 _ 或者 — ,如果是 —,请注意区分 — 和 - 减号

(一)四元式

四元式是普遍采用的一种中间代码形式,由于它便于优化处理,所以目前在很多编译程序中得到广泛应用。

形式 表示
一般形式 (op ,arg1 ,arg2 ,result)
一目运算 (op ,arg1 ,____ ,result)
0元运算 (op ,____ ,____,result)

如:a:= -b+c*d的四元式为:

(:= 表示赋值,用于区分 =)

(1) ( - , b , __ , T1 )

(2) ( * , c , d , T2 )

(3) ( + , T1 , T2 , T3 )

(4) ( := , T3 , __ , a )

T1 := -b

T2 := c * d

T3 := T1 + T2

a : = T3

四元式的最大优点:

在实现代码优化时,通常需要从现有的运算序列删去某些运算,或者需要挪动一些运算的位置,这对于四元式序列来说,是比较容易实现的。

因为四元式之间的联系是通过临时变量来实现的,所以更改其中一些四元式给整个序列带来的影响较小

(二)if 语句的翻译

描述 if 语句的文法如下:

if E then S1

或者

if E then S1 else S2

其中 E 为布尔表达式

S1,S2 本身也可以是 if 语句或者其他语句

控制语句中的回填技术

一些转移地址并不能不产生这些四元式的同时得知。

也就是说,一个布尔式的真假出口往往不能在产生四元式的同时就确定。

因此,要回填这些地址

拉链

为了记录需回填地址的四元式,采用 “拉链” 的方法。

把需回填 E.true 的四元式拉成一链,把需回填 E.false 的四元式拉成一链,分别称做“真”链和“假”链

IF 语句翻译过程

IF 语句翻译过程大致如下:

(1) 翻译 E,获得一组四元式;

(2) 扫描 E 的真出口,回填;

假出口尚不知;

(3) 翻译 S(1) ;

(4) 遇到 else,S(1) 结束,生成一条无条件转移四元式,但出口不明;

(5) 翻译 S(2) ,结束。

if 语句的翻译例题:

对下语句进行翻译:

if A > B or C then
if D<E then F:=F+1
else F:=F-1
else F:=0;

四元式从 100 开始编号:

100 ( j> , A , B , 104 )

101 ( j , _ , _ , 102 )

102 ( jnz, C , _ , 104 )

103 ( j , _ , _ , 112 )

104 ( j< , D , E , 106 )

105 ( j , _ , _ , 109 )

106 ( + , F , 1 , T1 )

107 ( := , T1 , _ , F )

108 ( j , _ , _ , 113 )

109 ( - , F , 1 , T2 )

110 ( := , T2 , _ , F)

111 ( j , _ , _ , 113 )

112 ( := , 0 , _ , F )

113 ...

解释:

(1)第 100 号 ( j> , A , B , 104 ) ,表式示如果满足 A > B,此时四元式第四个表示结果的是 104,就表示跳转到 104 号执行,是一个真出口;如果不满足就会继续走到下个序号的四元式 101 号。

(2)第 101 号 ( j , _ , _ , 102 ),表示直接到 102。虽然没有这一句也能到达 102,但是它表表示上面不满足的状态,也叫假出口,必须要写。

(3)所以写条件要一写一对,因为不满足就走到下一个序号的四元式,并且假出口只能在它相邻的下面。

(4)第 102 号 ( jnz, C , _ , 104 ),只有一个参数,操作符时 jnz,然后同样是满足则到 104,不满足走到下一个序号的四元式。

(5)第 106 号 ( + , F , 1 , T1 ),T1 是 F + 1 的结果,此时不表示跳转,不跳转也就是走到下个序号的四元式。

(6)注意赋值语句的表示,第 107 号 ( := , T1 , _ , F ),是将被赋值的元素放在结果的位置上,就是四元式第四个位置。

(三)while 语句的翻译

while 语句的翻译过程

while 语句的翻译过程大致如下:

(1) 翻译 E,待填 E 的真链、假链;

(2) 扫描 do 后,回填 E 的真链;

(3) 翻译 S 语句称代码段;

(4) 无条件转移到 E 代码段的第一条四元式,若 S 有语句链,也应转到 E 代码段的第一条四元式。

while 语句的翻译例题

对下语句进行翻译:

While (a<b) do
{ a=a+3;
b=b-3;
}

四元式从 100 开始编号:

101 (j<, a, b, 103) 真出口

102 (j, _ , _ , 108) 假出口

103 (+, a, 3, T1)

104 (:=, T1, _ , a)

105 (-, b, 3, T2)

106 (:=, T2, _ , b)

107 (j, _ , _ , 101)

108 ...

解释:

(1)原理同上

(2)注意赋值语句的表示,例如第 104 号 (:=, T1, _, a),是将被赋值的元素放在结果的位置上,就是四元式第四个位置。

《编译原理》控制流语句 if 和 while 语句的翻译 - 例题解析的更多相关文章

  1. 《编译原理》构造 LL(1) 分析表的步骤 - 例题解析

    <编译原理>构造 LL(1) 分析表的步骤 - 例题解析 易错点及扩展: 1.求每个产生式的 SELECT 集 2.注意区分是对谁 FIRST 集 FOLLOW 集 3.开始符号的 FOL ...

  2. 《编译原理》求 FIRSTVT 集和 LASTVT 集的步骤 - 例题解析

    <编译原理>求 FIRSTVT 集和 LASTVT 集的步骤 - 例题解析 算符优先关系表的构造中涉及到求 FIRSTVT 集和 LASTVT 集. 表示及含义: FIRSTVT(T) 非 ...

  3. x86汇编反编译到c语言之——(2)if语句

    一. 测试的C语句及编译后的x86汇编代码 int a; int b; int main(void) { int c; if (c) a = 4; else b = 5; return 0; } 1 ...

  4. 跟vczh看实例学编译原理——一:Tinymoe的设计哲学

    自从<序>胡扯了快一个月之后,终于迎来了正片.之所以系列文章叫<看实例学编译原理>,是因为整个系列会通过带大家一步一步实现Tinymoe的过程,来介绍编译原理的一些知识点. 但 ...

  5. 跟vczh看实例学编译原理——零:序言

    在<如何设计一门语言>里面,我讲了一些语言方面的东西,还有痛快的喷了一些XX粉什么的.不过单纯讲这个也是很无聊的,所以我开了这个<跟vczh看实例学编译原理>系列,意在科普一些 ...

  6. Compiler Theory(编译原理)、词法/语法/AST/中间代码优化在Webshell检测上的应用

    catalog . 引论 . 构建一个编译器的相关科学 . 程序设计语言基础 . 一个简单的语法制导翻译器 . 简单表达式的翻译器(源代码示例) . 词法分析 . 生成中间代码 . 词法分析器的实现 ...

  7. 编译原理_P1004

    龙书相关知识点总结 //*************************引论***********************************// 1. 编译器(compiler):从一中语言( ...

  8. 跟vczh看实例学编译原理——三:Tinymoe与无歧义语法分析

    文章中引用的代码均来自https://github.com/vczh/tinymoe.   看了前面的三篇文章,大家应该基本对Tinymoe的代码有一个初步的感觉了.在正确分析"print ...

  9. 必要的软件架构师——编译原理&#183;语法

    最近软测试.我观看进程的视频! 发现里面有很多内容已经在自我不错的接触过程.而占80%比例! 但其中的一部分.我很奇怪的一部分.研究,在这里,将我研究的内容整理分享给大家! 编译原理: 首先,我第一眼 ...

随机推荐

  1. springboot整合es客户端操作elasticsearch(三)

    继续上个随笔: 那么我们只需要修改controller中文件就可以完成相关操作 本次主要是对文档得操作: 更新文档: package com.cxy.elasticsearch.controller; ...

  2. ip地址查询python3小工具_V0.0.1

    看到同事在一个一个IP地址的百度来确认导出表格中的ip地址所对应的现实世界的地址是否正确,决定给自己新开一个坑.做一个查询ip“地址”的python小工具,读取Excel表格,在表格中的后续列输出尽可 ...

  3. [转帖]calico网络原理及与flannel对比

    calico网络原理及与flannel对比 https://blog.csdn.net/ganpuzhong42/article/details/77853131 2017年09月05日 16:34: ...

  4. Linux系列(10):入门之bash基础与bash环境设置

    了解什么是shell吗? 知道如何查询当前系统支持的shell版本吗? 了解如何判断某个指令是否是bash的内置指令吗? 了解Linux的变量吗,知道如何定义与删除变量吗,知道如何赋值吗,知道如何获取 ...

  5. 剑指offer5:用两个栈来实现一个队列,完成队列的Push和Pop操作。 队列中的元素为int类型。

    1. 题目描述 用两个栈来实现一个队列,完成队列的Push和Pop操作. 队列中的元素为int类型. 2. 思想 (1)栈的特点是先进后出,而队列的特点是先进先出: (2)因此,入队列的情况和入栈的情 ...

  6. [git] git error: unable to unlink old

    今天git pull ,结果报错 :   git error: unable to unlink old 原因是   文件夹内 一个exe 处于打开状态. 哈哈哈哈,又是个低级错误~~~ 下次注意呀~

  7. Spring 注解介绍

    @Component与@Bean的区别 @Component注解表明一个类会作为组件类,并告知Spring要为这个类创建bean. @Bean注解告诉Spring这个方法将会返回一个对象,这个对象要注 ...

  8. MyBatis学习存档(1)——入门

    一.简介 MyBatis的前身是iBatis,本是Apache的一个开源的项目 MyBatis是一个数据持久层(ORM)框架,把实体类和SQL语句之间建立了映射关系,是一种半自动化的ORM实现 MyB ...

  9. 【spring Boot】spring boot1.5以上版本@ConfigurationProperties取消location注解后的替代方案

    前言 =========================================== 初步接触Spring Boot ===================================== ...

  10. 怎样使用 vue-cli ( Vue 脚手架 )

    vue-cli 是 Vue 官方出品的快速构建单页应用的脚手架, 相当于 React 官方出品的 create-react-app , 下面演示 vue-cli 的 最 基本用法: 1. 全局安装 v ...