编译原理中间代码优化 .pdf
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_05.gif)
《编译原理中间代码优化 .pdf》由会员分享,可在线阅读,更多相关《编译原理中间代码优化 .pdf(39页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、实验三中间的代码优化某些编译程序在中间代码或目标代码生产之后要对其进行优化,所谓优化就是对代码进行等价的变换。而变换后的代码运行结果与变换前的代码运行结果相同。而运行速度加快或占用内存空间减少。中间的代码优化就是对中间代码进行等价的变换。基本块的有向图DAG(Directed Acyclic Graph)有向图中任何一条通路都不是环路,则称该有向图为无环路有向图,简称为DAG。一、实验题目:中间代码的局部优化二、实验目的:掌握局部优化方法、提高机器的运行速度三、实验内容:1、构造基本块内的优化DAG假设:(1)ni 为已知结点号,n 为新结点号;(2)访问各结点信息时,按结点号逆序排序2、完成
2、对下例三类表达式的优化(1)常值表达式的优化(2)公共表达式的优化(3)无用赋值的优化3、输出根据优化的DAG 重组四元式四、设计概要:首先要实现表达式中间代码生成,采用递归下降子程序法实现。ET 0“push(SYN,w)”T“QUAT”TF1”push(SYN,w)”F“QUAT”Fi“push(SEM,entry(w)”|(E)其中:push(SYN,w)-当前单词 w 入符号栈 SYN;push(SEM,entry(w)-当前 i 在符号表中的入口值压入语义栈SEM;QUAT-生成四元式函数 T:=newtemp;QTj=(SYNk,SEMs-1,SEMs,T);j+;pop(SYN,
3、_);pop(SEM,_);pop(SEM,_);push(SEM,T);名师资料总结-精品资料欢迎下载-名师精心整理-第 1 页,共 39 页 -在对中间代码进行局部优化名师资料总结-精品资料欢迎下载-名师精心整理-第 2 页,共 39 页 -五、程序代码及运行结果:1.表达式中间代码生成#include#include using namespace std;char str50;char sem50;char syn50;char ch;int i=0;int j=0;int n=0;int p=1;void push_sem(char w)semj+=w;void push_syn(c
4、har w)synn+=w;void Gen()char s22;char w;w=sem-j;if(w=1&w=1&w=9)s11=w;s10=sem-j;名师资料总结-精品资料欢迎下载-名师精心整理-第 3 页,共 39 页 -else s10=w;s11=;cout(syn-n,s10s11,s00s01,tp+)endl;push_sem(t);push_sem(p+47);int F()int m;int E();if(ch=()ch=stri+;m=E();if(ch=)ch=stri+;else /cout表达式 error!=a&ch=1&ch=9)push_sem(ch);c
5、h=stri+;else /cout表达式 error!endl;return 0;return 1;int T()名师资料总结-精品资料欢迎下载-名师精心整理-第 4 页,共 39 页 -int k,m,l;k=F();if(k=0)return 0;while(1)/push_syn(ch);if(ch=*)push_syn(ch);ch=stri+;m=F();if(m=0)return 0;Gen();else if(ch=/)push_syn(ch);ch=stri+;l=F();if(l=0)return 0;Gen();else break;return 1;int E()int
6、 k,m,l;k=T();if(k=0)return 0;while(1)/push_syn(ch);if(ch=+)push_syn(ch);ch=stri+;m=T();if(m=0)return 0;Gen();else if(ch=-)名师资料总结-精品资料欢迎下载-名师精心整理-第 5 页,共 39 页 -push_syn(ch);ch=stri+;l=T();if(l=0)return 0;Gen();else break;return 1;int main()int k,q=0;char w1,w2,w;char s12;coutstr;w1=stri+;w2=stri+;if(
7、w2!=)i=i-2;q=1;ch=stri+;k=E();if(q=0)w=sem-j;if(w=1&w=9)s01=w;s00=sem-j;else s00=w;s01=;cout(w2,s00s01,w1)endl;if(k=0)couterror!endl;else if(ch=#)coutOK!endl;else couterror!endl;名师资料总结-精品资料欢迎下载-名师精心整理-第 6 页,共 39 页 -return 0;运行结果:2.代码优化:(采用递归下降子程序法判断表达式是否合法,方法如上)#include#include#include using namespa
8、ce std;int i=1;int j=0,n=0;int p;int m=1;int Ti=0;char prog100;char ch;char syn20,sem503;void SEM(void)int i,j;for(i=0;i50;i+)for(j=0;j3;j+)semij=0;struct quat/四元式结构 char result8;char ag18;char op;char ag28;名师资料总结-精品资料欢迎下载-名师精心整理-第 7 页,共 39 页 -quad25,newquad15;struct Ni/节点结构 int pre2;char op;char bz
9、258;N25;void newN(void)int l,j;i+;for(j=0;j25;j+)for(l=0;l8;l+)Ni-1.bzjl=0;for(j=0;j2;j+)Ni-1.prej=0;Ni-1.op=0;void dagt(void);void newquat(void);void fuzhi(void);/递归语法分析生成中间代码void E(void);void T(void);void F(void);void pop0(char sz);void push0(char sz,char x);void pop1(char sz503);void push1(char s
10、z503,char x3);void quat1(void);void quat0(char w);void print1(void);void print2(void);char*newT(void)char*p;char m8;p=(char*)malloc(8);Ti+;itoa(Ti,m,10);名师资料总结-精品资料欢迎下载-名师精心整理-第 8 页,共 39 页 -strcpy(p+1,m);p0=t;return(p);void main()p=0;syn0=#;SEM();sem00=#;cout 请输入表达式:endl;do cin.get(ch);if(ch!=n)prog
11、p+=ch;while(ch!=#);p=0;ch=progp+;while(ch!=#)fuzhi();print1();dagt();newquat();print2();void fuzhi(void)char temp3;temp0=0;temp1=0;temp2=0;if(ch=a)|(ch=A)temp0=ch;push1(sem,temp);ch=progp+;if(ch=)push0(syn,ch);ch=progp+;名师资料总结-精品资料欢迎下载-名师精心整理-第 9 页,共 39 页 -E();if(m=0)cout 错误 1!endl;system(pause);/re
12、turn;if(ch=;)ch=progp+;quat1();else cout 错误 2!endl;system(pause);return;else cout 错误 3!endl;system(pause);return;else cout 错误 4!endl;printf(%d,ch);system(pause);return;/E、T、F是递归下降子程序的语法分析void E(void)char w;T();while(ch=+|ch=-)push0(syn,ch);w=synstrlen(syn)-1;ch=progp+;名师资料总结-精品资料欢迎下载-名师精心整理-第 10 页,共
13、 39 页 -T();quat0(w);void T(void)char w;F();while(ch=*|ch=/)push0(syn,ch);w=synstrlen(syn)-1;ch=progp+;F();quat0(w);void F(void)char temp3;temp0=0;temp1=0;temp2=0;if(ch=()ch=progp+;E();if(ch=)ch=progp+;else m=0;else if(ch=a)|(ch=A)|(ch=0)temp0=ch;push1(sem,temp);ch=progp+;else m=0;名师资料总结-精品资料欢迎下载-名师精
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 编译原理中间代码优化 2022 编译 原理 中间 代码 优化
![提示](https://www.taowenge.com/images/bang_tan.gif)
限制150内