编译原理(第四版)第5篇 章 代码优化.ppt

  1. 1、本文档共175页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
编译原理(第四版)第5篇 章 代码优化.ppt

5.1 局部优化 5.2 循环优化 5.3 全局优化概述 5.4 代码优化示例 习题五 ;  源程序经过词法分析、语法分析、语义分析等阶段的编译工作,得到了与源程序功能等价的中间代码。但是,由于这种中间代码是“机械生成”的结果,因而必然存在效率不高和有冗余代码的现象,还需进行代码优化。代码优化的含义是:对代码进行等价变换,使得变换后的代码具有更高的时间效率和空间效率。代码优化的目的是提高目标程序的质量。   优化可以在编译的不同阶段进行,但最主要的一类优化是在目标代码生成以前进行的,即对语义分析后的中间代码进行优化,这种优化的优点是不依赖于具体的计算机。另一类重要的优化是在生成目标代码时进行的,它在很大程度上依赖于具体的计算机。本章讨论前一种与机器无关的中间代码优化。;  根据优化对象所涉及的程序范围,优化又分为局部优化、循环优化和全局优化。一个程序从结构上看,作为结点的基本块是其基础。因为基本块的结构最简单、因素最单纯,所以它也是优化的基础,对基本块的优化就是局部优化。循环是程序中要反复执行的部分,优化的效益当然很大,所以循环优化是优化工作的一个重点。针对整个程序的优化即全局优化,它涉及到对程序数据流分析的问题。我们在此主要讨论局部优化与循环优化。   为了叙述方便,从本章开始把四元式写成更为直观的三地址代码形式,如: (op, B, C, A)? A=B op C (jrop, B, C, L)? if B rop C goto L (j, _, _, L)? goto L;5.1 局 部 优 化 5.1.1 基本块的划分方法   所谓基本块,是指程序中一顺序执行的语句序列,其中只有一个入口和一个出口,入口就是该序列的第一个语句,出口就是该序列的最后一个语句。对一个基本块来说,执行时只能从其入口进入,从其出口退出。对一个给定的程序,我们可以把它划分为一系列基本块,在各个基本块范围内进行的优化称为局部优化。划分基本块的关键问题是准确定义入口和出口语句。下面我们给出划分四元式程序为基本块的算法:   (1) 从四元式序列确定满足以下条件的入口语句:   ① 四元式序列的第一个语句;   ② 能??条件转移语句或无条件转移语句转移到的语句;   ③ 紧跟在条件转移语句后面的语句。;  (2) 确定满足以下条件的出口语句:   ① 下一个入口语句的前导语句;   ② 转移语句(包括转移语句自身);   ③ 停语句(包括停语句自身)。;  (3) 图中各个结点上可能附加一个或多个标识符,表示这些变量具有该结点所代表的值。   一个基本块由一个四元式序列组成,且每一个四元式都可以用相应的DAG结点表示。图5–1给出了不同四元式和与其对应的DAG结点形式。图中,各结点圆圈中的ni是构造DAG过程中各结点的编号,而各结点下面的符号(运算符、标识符或常数)是各结点的标记,各结点右边的标识符是结点上的附加标识符。除了对应转移语句的结点右边可附加一语句位置来指示转移目标外,其余各类结点的右边只允许附加标识符。除对应于数组元素赋值的结点(标记为[ ]=)有三个后继外,其余结点最多只有两个后继。;图5–1 四元式与DAG结点 ;  利用DAG进行基本块优化的基本思想是:首先按基本块内的四元式序列顺序将所有的四元式构造成一个DAG,然后按构造结点的次序将DAG还原成四元式序列。由于在构造DAG的同时已做了局部优化,所以最后所得到的是优化过的四元式序列。   为了DAG构造算法的需要,我们将图5–1中的四元式按照其对应结点的后继结点个数分为四类:   (1) ?0型四元式:后继结点个数为0,如图5–1(1)所示;   (2) ?1型四元式:有一个后继结点,如图5–1(2)所示;   (3) ?2型四元式:有两个后继结点,如图5–1(3)、(4)、(5)所示;   (4) ?3型四元式:有三个后继结点,如图5–1(6)所示。;  我们规定:用大写字母(如A、B等)表示四元式中的变量名(或常数);用函数Node(A)表示A在DAG中的相应结点,其值可为n或者无定义,并用n表示DAG中的一个结点值。这样,每个基本块仅含0、1、2型四元式的DAG构造算法如下(对基本块的每一个四元式依次执行该算法):   (1) 若Node(B)无定义,则构造一标记为B的叶结点并定义Node(B)为这个结点,然后根据下列情况做不同处理:   ① 若当前四元式是0型,则记Node(B)的值为n,转(4)。   ② 若当前四元式是1型,则转(2)①。   ③ 若当前四元式是2型,则:   i. 如果Node(C)无定义,则构造一标记为C的叶结点,并定义Node(C)为这个结点;   ii. 转(2)②。;  (2) ① 若Nod

文档评论(0)

youngyu0329 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档