- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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=-
您可能关注的文档
- 程序设计语言与编译ppt课件_0 课程简介.pptx
- 程序设计语言与编译ppt课件_6.2 词法分析器实例.pptx
- 程序设计语言与编译ppt课件_7.6 LR分析法.pptx
- 程序设计语言与编译ppt课件_7.2 回溯分析法.pptx
- 程序设计语言与编译ppt课件_7.1 语法分析概述.pptx
- 程序设计语言与编译ppt课件_4.2.3 文法和语言.pptx
- 程序设计语言与编译ppt课件_4.1 程序设计语言的定义.pptx
- 程序设计语言与编译ppt课件_6.1 词法分析概述+单词的类别+单词的识别.pptx
- 程序设计语言与编译ppt课件_10.4 存储空间分配.pptx
- 程序设计语言与编译ppt课件_10.1 目标代码生成概述.pptx
- 程序设计语言与编译ppt课件_8.3 说明语句的翻译.pptx
- 程序设计语言与编译ppt课件_8.5 goto语句的翻译.pptx
- 程序设计语言与编译ppt课件_8.4 赋值语句的翻译.pptx
- 程序设计语言与编译ppt课件_8.1 语义分析概述.pptx
- 程序设计语言与编译ppt课件_5.2 编译的步骤.pptx
- 程序设计语言与编译ppt课件_4.2.1 形式语言与自动机理论.pptx
- 程序设计语言与编译ppt课件_5.1 语言的翻译+编译与解释.pptx
- 程序设计语言与编译ppt课件_2.2 内部类型.pptx
- 程序设计语言与编译ppt课件_2.1 引言.pptx
- 程序设计语言与编译ppt课件_7.5 算符优先分析法.pptx
原创力文档


文档评论(0)