- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
编译原理ch5
第五章语法制导翻译和中间代码⽣成
• §5.1 概述
• 语义分析包含静态语义检查和语义识别,并在此基
础上对源程序(单词串形式)进行等价转换,转换
为中间代码(目标代码)。
• 在后面的讨论中总是认为词法、语法分析已经完成,
读入的是(语法正确)句子!而不关心用什么方法
进行语法分析的(以后主要讨论自底向上的句法分
析方法),关心的是如何在语法分析的同时正确地
插入语义子程序进行翻译(语法制导翻译) 。
6/5/14 华东师范大学计算机科学技术系 1
⼀、静态语义检查
• 称在编译时刻进行的语义检查为静态语义检查,通
常可包含如下内容:
(1) 类型检查。
检查运算的合法性和参与运算的运算分量类型的一
致性(相容性)。必要时进行相应的类型转换。
(2) 控制流检查。
以保证控制语句有合法的转向点,如C语言中的
break语句,需寻找包含它的最小的switch 、while
或for语句,方可找到转向点,否则出错。不允许
循环外控制转入循环内。
6/5/14 华东师范大学计算机科学技术系 2
(3) 有关名字的匹配检查。
可以对某些程序段命名,该名字出现在程序段的开
始和结束处,如同语句括号一般,应检查它们的配
对。
(4) 一致性检查。
如在相同作用域中标识符只能说明一次(重复定
义),case语句的标号不能相同,枚举类型的元素
不能重复,没有定义数据类型等。
6/5/14 华东师范大学计算机科学技术系 3
⼆、语法制导翻译
• 例1:对算术表达式文法G[E]的一个翻译方案
E→E+T {print “1”}
E→T {print “2”}
T→T*F {print “3”}
T→F {print “4”}
F→(E) {print “5”}
F→i {print “6”}
其中{ }括起的称为该产生式的语义子程序。
对输入串W=(i+i)*i 则W是G的一个句子。
6/5/14 华东师范大学计算机科学技术系 4
E
• 若采用自底向上的句法分析,规
T 定当用产生式A→α归约时,调
用相应的语义子程序,则翻译结
T * F 束后输出 64264154632 。
F i • 若采用自顶向下的句法分析,规
定当用产生式A→α推导时,调
( E ) 用相应的语义子程序,则翻译结
E + T 束后输出 23451246466 。
T F
• 应根据输出(翻译)目标,配备
F i 适当的语义子程序,这就是所要
做的工作。
i
6/5/14 华东师范大学计算机科学技术系 5
三、翻译要解决的问题
1. 翻译成什么样的目标
原创力文档


文档评论(0)