- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
编译原理教案9
5.3 常见中间语言简介
在着手讨论各种语法结构的语法制导翻译之前,我们首先应介绍一下目前经常使用的几种中间语言的形式。这是因为,语义子程序的设计,不仅依赖于相应语法结构中各个量的语义,而且还取决于要产生什么形式的中间代码.
5.3.1 逆波兰表示
波兰逻辑学家J.Lukasiewicz于1929年提出了另一种表示表达式的方法。按此方法,每一运算符都置于其运算对象之后,故称为后缀表示。
特点:表达式中各个运算是按运算符出现的顺序进行的,故无须使用括号来指示运算顺序,因而又称为无括号式。下面我们对照地给出一些表达式的两种表示:
中缀表示 后缀表示
A+B AB+
A+B*C ABC*+
(A+B)*(C+D) AB+CD+*
x/y^z-d*e xyz^/de*-
(a=0b3)(exy) a0=b3exy
逆波兰式的特点
①在两种表示中,运算对象出现的顺序相同;
②在后缀表示中,运算符按实际计算顺序从左到右排列,且每一运算符总是跟在其运算对象之后。
由于后缀表示中的各个运算是按顺序执行的,因此,它的计值需从左到右依次扫视表达式中的各个符号,
每遇一运算对象,就把它压入栈顶暂存起来;
每遇一个二元(或一元)运算符时,就取出栈顶的两个(或一个)运算对象进行相应的运算,并用运算结果去替换栈顶的这两(或一)个运算对象;
继续扫视余留的符号,直到扫视完整个表达式为止。
当上述过程结束时,整个表达式的值将留于栈顶。
逆波兰表示的扩充
逆波兰表示还可用于表示其它的语法结构。此时,运算符不再限于算术、关系和逻辑运算符,每个运算符的操作对象也可以不止两个。例如,赋值语句x:=a+b*c可按后缀式写为x abc*+:=。
为了用后缀式表示一些控制语句,我们假定将后缀式的各符号存放在一个一维数组POST[n]中.还需引入一些转移操作符:
p BR—无条件转至POST[p](从POST[p] 继续执行);
e’ p BZ—e’是e的后缀表示,当e’之值为零时,转向POST[p];
e1’ e2’ p BL—e1’和e2’分别是e1和e2的后缀表示,当 e1’e2’时,转向POST[p];
类似地,我们还可以定义BN(非零转)、BP(正号转)、BM(负号转)等等。于是,条件语句IF e THEN S1 ELSE S2 可写成
e’ p1 BZ S1’ p2 BR S2‘
其中, p1表示S2‘在数组POST中的起始位置; p2表示位于S2‘之后那个符号的位置。
例:翻译表达式的S-属性文法
⒈Expr→ Expr ‘+’ Term {$$=$1;POST[p] =‘+’;p++;}
⒉ | Term {$$=$1;}
⒊Term→ Term ’*’ Factor {$$=$1;POST[p] =‘*’; p++;}
⒋ | Factor{$$=$1;}
⒌Factor→ ‘(‘ Expr ‘)’ { $$=$2;}
⒍ |iden{$$=p; POST[p] =$1; p++;}
我们以第3式为例介绍其原理。
首先,产生式左部Term的首地址显然应与右部第一符号对应的首地址相同($$=$1;)。
其次,按第3式归约时,或者说,翻译文法执行该语义动作时,右部符号Term和Factor对应的输出(即各自所代表的代码段)已经建立,并已存储在POST中,它们恰好就是运算符‘*’的两个运算对象,所以,现在将‘*’输出到POST中是合适的。
最后,因POST[p]已被赋值(即翻译所得的部分代码已输出),应将下标计数加一。
对A+B*C进行分析翻译的过程
5.3.2 四元式和三元式
四元式是一种更接近目标代码的中间代码形式,由于这种形式的中间代码便于优化处理,因此,在目前的许多编译程序中得到了广泛的应用。
四元式是一种“三地址语句”的等价表示。它的一般形式为:(op,arg1,arg2,result)
其中,op为一个二元(也可是一元或零元)运算符; arg1,arg2分别为它的两个运算对象,它们可以是变量、常数或系统定义的临时变量名;运算的结果将放入result中。四元式还可写为类似于PASCAL语言的赋值语句的形式:
result := arg1 op arg2
四元式的格式
需要指出的是,每个四元式只能有一个运算符,所以,一个复杂的表达式只能由多个四元式构成的序列表示。
例如,表达式A+B*C可写为序列
T1:=B*C
T2:=A+T1
当op为一元、零元运算(如无条件转移)时,arg2甚至arg1应缺省,即result:=op arg1或 op result ;对应的一般形式为:
(op,arg1,-,resul
您可能关注的文档
- 细菌耐医药监测意义及临床微生物标本的采集.ppt
- 经典实用教案:创新管理综合案例(中国企业职业经理人).ppt
- 经典实用有价值企业管理培训教案:特劳特品牌战略系列教程.ppt
- 经典实用有价值企业管理培训教案:持续提升客户满意度与忠诚度.ppt
- 经典实用有价值的企业管理培训教案:中国企业为什么要学习海尔经验.ppt
- 细菌第部分绪论.ppt
- 经典实用有价值的企业管理培训教案:品牌战略筹备.ppt
- 经典实用有价值的企业管理培训教案:构建客户忠诚度的六大途径.ppt
- 经典实用有价值的企业管理培训教案:国际著名策划公司教程ARS营销战略教程.ppt
- 经典实用有价值的企业管理培训教案:渠道营销与分销策略.ppt
文档评论(0)