网站大量收购独家精品文档,联系QQ:2885784924

编译原理课件55094.pptVIP

  1. 1、本文档共15页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
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=0?b3)?(e?xy) a0=b3?exy?? 逆波兰式的特点 ①在两种表示中,运算对象出现的顺序相同; ②在后缀表示中,运算符按实际计算顺序从左到右排列,且每一运算符总是跟在其运算对象之后。 由于后缀表示中的各个运算是按顺序执行的,因此,它的计值需从左到右依次扫视表达式中的各个符号, 每遇一运算对象,就把它压入栈顶暂存起来; 每遇一个二元(或一元)运算符时,就取出栈顶的两个(或一个)运算对象进行相应的运算,并用运算结果去替换栈顶的这两(或一)个运算对象; 继续扫视余留的符号,直到扫视完整个表达式为止。 当上述过程结束时,整个表达式的值将留于栈顶。 逆波兰表示的扩充 逆波兰表示还可用于表示其它的语法结构。此时,运算符不再限于算术、关系和逻辑运算符,每个运算符的操作对象也可以不止两个。例如,赋值语句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]已被赋值(即翻译所得的部分代码已输出),应将下标计数加一。 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,-,result) 或 (op

文档评论(0)

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

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

版权声明书
用户编号:5311233133000002

1亿VIP精品文档

相关文档