编译原理教程 第三版 教学课件 作者 胡元义 全书 第5章.ppt

编译原理教程 第三版 教学课件 作者 胡元义 全书 第5章.ppt

  1. 1、本文档共186页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
  源程序经过词法分析、语法分析、语义分析等阶段的编译工作,得到了与源程序功能等价的中间代码。但是,由于这种中间代码是“机械生成”的结果,因而必然存在效率不高和有冗余代码的现象,还需进行代码优化。代码优化的含义是:对代码进行等价变换,使得变换后的代码具有更高的时间效率和空间效率。代码优化的目的是提高目标程序的质量。   优化可以在编译的不同阶段进行,但最主要的一类优化是在目标代码生成以前进行的,即对语义分析后的中间代码进行优化,这种优化的优点是不依赖于具体的计算机。 另一类重要的优化是在生成目标代码时进行的,它在很大程度上依赖于具体的计算机。本章讨论前一种与机器无关的中间代码优化。   根据优化对象所涉及的程序范围,优化又分为局部优化、循环优化和全局优化。一个程序从结构上看,作为结点的基本块是其基础。因为基本块的结构最简单、因素最单纯,所以它也是优化的基础,对基本块的优化就是局部优化。循环是程序中要反复执行的部分,优化的效益当然很大,所以循环优化是优化工作的一个重点。针对整个程序的优化即全局优化,它涉及到对程序数据流分析的问题。   为了叙述方便,从本章开始把四元式写成更为直观的三地址代码形式,如:   (op, B, C, A) ? A?=?B op C   (jrop, B, C, L) ? if B rop C goto L   (j, _, _, L) ? goto L      局部优化是指对代码的每一个线性部分所进行的优化,使得在这个线性部分只存在一个入口和一个出口,而这个线性部分我们称之为基本块。 5.1.1 基本块的划分方法   所谓基本块,是指程序中一顺序执行的语句序列,其中只有一个入口和一个出口,入口就是该序列的第一个语句,出口就是该序列的最后一个语句。对一个基本块来说,执行时只能从其入口进入,从其出口退出。对一个给定的程序,我们可以把它划分为一系列基本块,在各个基本块范围内进行的优化称为局部优化。划分基本块的关键问题是准确定义入口和出口语句。   下面我们给出划分四元式程序为基本块的算法。   (1) 从四元式序列确定满足以下条件的入口语句:   ① 四元式序列的第一个语句;   ② 能由条件转移语句或无条件转移语句转移到的语句;   ③ 紧跟在条件转移语句后面的语句。   (2) 确定满足以下条件的出口语句:   ① 下一个入口语句的前导语句;   ② 转移语句(包括转移语句自身);   ③ 停语句(包括停语句自身)。   例如,考察下面求最大公因子的三地址代码程序:   (1)? read X   (2)? read Y   (3)? R=X % Y   (4)? if R=0 goto(8)   (5)? X=Y   (6)? Y=R   (7) ?goto(3)   (8) ?write Y   (9) ?halt   根据上述划分基本块的算法可确定四元式(1)、(3)、(5)、(8)是入口语句,而四个基本块分别是:(1)(2),(3)(4),(5)(6)(7),(8)(9)。 5.1.2 基本块的DAG方法   DAG(Directed Acyclic Graph)是一种有向图,常常用来对基本块进行优化。一个基本块的DAG是一种其结点带有下述标记或附加信息的DAG:   (1) 图的叶结点(无后继的结点)以一标识符(变量名)或常数作为标记,表示该结点代表该变量或常数的值。如果叶结点用来表示一变量A的地址,则用addr(A)作为该结点的标记。通常把叶结点上作为标记的标识符加上下标0,以表示它是该变量的初值。   (2) 图的内部结点(有后继的结点)以一运算符作为标记,表示该结点代表应用该运算符对其直接后继结点所代表的值进行运算的结果。   (3) 图中各个结点上可能附加一个或多个标识符,表示这些变量具有该结点所代表的值。   一个基本块由一个四元式序列组成,且每一个四元式都可以用相应的DAG结点表示。图5-1给出了不同四元式和与其对应的DAG结点形式。   图中,各结点圆圈中的ni是构造DAG过程中各结点的编号,而各结点下面的符号(运算符、标识符或常数)是各结点的标记,各结点右边的标识符是结点上的附加标识符。除了对应转移语句的结点右边可附加一语句位置来指示转移目标外,其余各类结点的右边只允许附加标识符。除对应于数组元素赋值的结点(标记为[ ]=?)有三个后继外,其余结点最多只有两个后继。    图5-1 四元式与DAG结点   利用DAG进行基本块优化的基本思想是:首先按基本块内的四元式序列顺序将所有的四元式构造成一个DAG,然后按构造结点的次序将DAG还原成四元式序列。由于在构造DAG的同时已做了局部优化,所以最后所得到的是优化过的四元式序列。   为了DAG构造算法的需要,

您可能关注的文档

文档评论(0)

118压缩包课件库 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档