程序设计语言与编译ppt课件_8.6 if语句的翻译.pptxVIP

程序设计语言与编译ppt课件_8.6 if语句的翻译.pptx

  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文档。上传文档
查看更多

第八章语义分析第五节goto语句的翻译第六节if语句的翻译第七节while语句的翻译第八节for语句的翻译

示例语言的if语句:if(a){b=1;}if(a+b){c=1;}if(a){b=1;c=2;}if(a){b=1;c=2;if(d){e=1;}}采用下列文法:S_list→S_listS|SS→if(E){S_list}if语句的翻译

S_list→S { S_list.tac=S.tac}S_list→S_list1S { S_list.tac=S_list1.tac S_list.tac+=S.tac}语义子程序

S→if(E){S_list} { S.tac=E.tac L=new_label() sym_add(L) S.tac+=tac(ifzE.addrgotoL) S.tac+=S_list.tac S.tac+=tac(labelL)} 语义子程序

源程序if(a){ a=-b*(c+d); b=a;}翻译实例归约过程1. a归约到E2. a=-b*(c+d);归约到S13. S1归约到S_list14. b=a;归约到S25. S_list1S2归约到S_list26. if(E){S_list2}归约到S

2. a=-b*(c+d);归约到S1vart1t1=-bvart2t2=c+dvart3t3=t1*t2a=t3翻译实例4. b=a;归约到S2b=a5. S_list1S2归约到S_list2vart1t1=-bvart2t2=c+d

vart3t3=t1*t2a=t3b=a6. if(E){S_list2}归约到SifzagotoL1vart1翻译实例t1=-bvart2t2=c+dvart3t3=t1*t2a=t3b=alabelL1

符号表翻译实例编号属性1a、变量、int2b、变量、int3c、变量、int……10t1、临时变量、int11t2、临时变量、int12t3、临时变量、int13L1、标号、label……

语句实例:if(a){b=1;}else{b=2;}if(a+b){b=1;}else{b=2;}if(a){b=a+1;c=b+2;}else{b=2;c=3;}if(a){if...{if...else...}...}else{if...{if...{if...else...}...}...};采用下列文法:S→if(E){S_list1}else{S_list2}if-else语句的翻译

S→if(E){S_list1}else{S_list2}{ S.tac=E.tac L1=new_label() sym_add(L1) S.tac+=tac(ifzE.addrgotoL1) S.tac+=S_list1.tac语义子程序 L2=new_label() sym_add(L2) S.tac+=tac(gotoL2) S.tac+=tac(labelL1) S.tac+=S_list2.tac S.tac+=tac(labelL2)}

源程序if(a){ a=-b*(c+d); b=a;}else { c=a;}翻译实例归约过程1. a归约到E2. a=-b*(c+d);b=a;归约到S_list13. c=a;归约到S_list24. if(E){S_list1}else{S_list2}归约到S

2.a=-b*(c+d);b=a;归约到S_list1vart1t1=-bvart2t2=c+dvart3t3=t1*t2a=t3b=a翻译实例3. c=a;归约到S_list2c=a

4. if(E){S_list1}else{S_list2}归约到SifzagotoL1vart1t1=-

文档评论(0)

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

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

1亿VIP精品文档

相关文档