长安大学《编译原理》chapter8.pdfVIP

  1. 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
软件工程专业本科课程 编 译 原 理 Compilers Principles 长安大学信息工程学院计算机系 主讲:李 鹏 第八章 代码生成 本章内容 • 一个简单的代码生成算法 • 涉及存储管理,指令选择,寄存器分配和计算 次序选择等基本问题 源程序 中间代码 代码 中间代码 代码 目标程序 前端 生成 优化器 器 2 8.1 代码生成器设计中的问题 代码生成器的输入 代码生成器的输入是由前端生成的源程序的中间 表示形式以及符号表中的信息组成。 中间表示(IR )的表达形式可以有多种选择。 8.1 代码生成器设计中的问题 3 目标程序 机器代码的代码生成器受目标机器的指令体系结构影响 非常大。 • 可执行目标模块 • 可重定位目标模块  允许程序模块分别编译  调用其它先前编译好的程序模块 • 汇编语言程序 8.1 代码生成器设计中的问题 4 指令选择 目标机器指令系统的性质决定了指令选择的难易 程度,指令系统的统一性和完备性是重要的因素。 指令的速度和机器特点是另一些重要的因素。 8.1 代码生成器设计中的问题 5 若不考虑目标程序的效率,指令的选择很简单。 三地址语句x = y + z (x,y和z都是静态分配) LD R0, y /* 把y装入寄存器R0 */ ADD R0, R0, z /* z加到R0上*/ ST x, R0 /* 把R0存入x 中*/ 逐个语句地产生代码,常常得到低质量的代码 8.1 代码生成器设计中的问题 6 语句序列 a = b + c d = a + e 的代码如下 多余的指令。若a LD R0, b 不再使用,第三条 ADD R0, R0, c 也多余。 ST a, R0 LD R0, a ADD R0, R0, e ST d, R0 8.1 代码生成器设计中的问题 7 寄存器分配 运算对象处于寄存器中的指令通常比运算对象 处于内存的指令要短一些,执行也快一些。 • 寄存器分配 选择驻留在寄存器中的一组变量 • 寄存器指派 挑选变量要驻留的具体寄存器 8.1 代码生

文档评论(0)

1243595614 + 关注
实名认证
文档贡献者

文档有任何问题,请私信留言,会第一时间解决。

版权声明书
用户编号:7043023136000000

1亿VIP精品文档

相关文档