编译原理中间代码优化_第1页
编译原理中间代码优化_第2页
编译原理中间代码优化_第3页
编译原理中间代码优化_第4页
编译原理中间代码优化_第5页
已阅读5页,还剩1页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

实用标准文案实验三 中间的代码优化某些编译程序在中间代码或目标代码生产之后要对其进行优化, 所谓优化就是对代码进行等价的变换。而变换后的代码运行结果与变换前的代码运行结果相同。而运行速度加快或占用内存空间减少。 中间的代码优化就是对中间代码进行等价的变换。基本块的有向图 DAG(Directed Acyclic Graph)有向图中任何一条通路都不是环路,则称该有向图为无环路有向图,简称为DAG。一、实验题目:中间代码的局部优化二、实验目的:掌握局部优化方法、提高机器的运行速度三、实验内容:1、构造基本块内的优化 DAG假设:(1)ni为已知结点号,n为新结点号;(2)访问各结点信息时,按结点号逆序排序2、完成对下例三类表达式的优化1)常值表达式的优化2)公共表达式的优化3)无用赋值的优化3、输出根据优化的 DAG重组四元式精彩文档实用标准文案四、设计概要:首先要实现表达式中间代码生成,采用递归下降子程序法实现。E→T{ω0“push(SYN,w)”T“QUAT”}T→F{ω1”push(SYN,w)”F“QUAT”}F→i“push(SEM,entry(w)) ”|(E)其中:·push(SYN,w)--- 当前单词w入符号栈SYN;·push(SEM,entry(w))--- 当前i在符号表中的入口值压入语义栈 SEM;·QUAT---生成四元式函数T:=newtemp;QT[j]=(SYN[k],SEM[s-1],SEM[s],T);j++;pop(SYN,_);pop(SEM,_);pop(SEM,_);push(SEM,T);精彩文档实用标准文案精彩文档实用标准文案在对中间代码进行局部优化五、程序代码及运行结果:表达式中间代码生成#include<iostream>#include<cstdlib>usingnamespacestd;charstr[50];charsem[50];charsyn[50];charch;inti=0;intj=0;intn=0;intp=1;voidpush_sem(charw){sem[j++]=w;}voidpush_syn(charw){syn[n++]=w;}精彩文档实用标准文案voidGen(){chars[2][2];charw;w=sem[--j];if(w>='1'&&w<='9'){s[0][1]=w;s[0][0]=sem[--j];}else{s[0][0]=w;s[0][1]='';}w=sem[--j];if(w>='1'&&w<='9'){s[1][1]=w;s[1][0]=sem[--j];}else精彩文档实用标准文案{s[1][0]=w;s[1][1]='';}cout<<"("<<syn[--n]<<","<<s[1][0]<<s[1][1]<<","<<s[0][0]<<s[0][1]<<","<<'t'<<p++<<")"<<endl;push_sem('t');push_sem(p+47);}intF(){intm;i

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论