- 1、本文档共56页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第8章 语法制导翻译和中间代码生成 经过词法分析、语法分析后,源程序在静态结构上的正确性得到了保证,编译程序接着要对源程序进行静态语义检查和翻译。 语义检查:类型检查、控制流检查、一致性检查等。 翻译:源程序→中间代码 本章主要内容 1. 属性文法 2. 语法制导翻译概念 3. 中间代码的几种形式 4. 几个语句的翻译:如赋值语句、条件语句等。 语法制导翻译的引例 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”} 对(i+i)*i的翻译 不难证明该符号串是文法的合法句子。按照这个句子向文法开始符号E的归约次序,且每当归约时调用该句柄的产生式所对应的语义子程序,便可得到相应的数字串:64264154632。 这个例子表明:输入源程序为(i+i)*i,输出为数字串。这是一种变换,而变换的规则是每当归约时调用相应的语义子程序。无疑这个例子是翻译的一个十分简单的模型。 翻译要解决的问题 1. 翻译成什么样的代码? 2. 什么时候实现这种变换(翻译)? 3. 如何实现这种翻译? 翻译成什么样的代码 按照相应语义规则产生一种介于源语言与目标代码之间的一种代码(中间代码),它不依赖于机器但又便于产生依赖于机器的目标代码。 中间代码可用多种方式表示,常见的有:逆波兰表示法、树形表示法、三元式、四元式等。 什么时候实现这种变换(翻译) 直观来说,就是为每个产生式配上一个翻译子程序(语义子程序),并且在语法分析的同时执行这些子程序。 具体来说,就是一边分析,一边翻译,语法分析完成,翻译也就完成了。 语法制导翻译法对自上而下分析或自下而上分析都适用。 语法制导翻译方法是比较接近于形式化的翻译方法。 如何实现这种翻译 至此不难明白,语法制导翻译的关键是为每个产生式写相应的语义子程序。 例子中的print产生式序号这种语义子程序是为了输出数字串而写的语义子程序。所以一个语义子程序描述了一个产生式对应的翻译工作。 这些工作有:改变编译程序某些变量的值、查填各种符号表、发现并报告源程序错误、产生中间代码。 语义子程序的一般形式 语义子程序写在该产生式后面的花括号内: (1) X?… { 语义子程序1 } (2) Y?… { 语义子程序2 } (3) A?XY { 语义子程序3 } 属性文法与语法制导翻译的关系 对于某个压缩了的文法,当把每个文法符号和一组属性相关联,并把产生式附加以语义规则的时候,就得到属性文法。 语法制导的翻译过程:由于属性文法的规则和产生式是一一对应的关系。所以,由属性文法确定的语义分析可以在语法分析的过程中进行。这个过程成为语法制导的翻译。 属性文法 属性文法是一个三元组:A=(G,V,F),其中 G:是一个上下文无关文法。 V:属性的有穷集,每个属性与文法的一个终结符或非终结符相连,这些属性代表与文法符号相关信息,如它的类型、值、代码序列、符号表内容等等 .属性与变量一样,可以进行计算和传递。 属性文法 F:关于属性的属性断言或一组属性的计算规则(称为语义规则) 。 断言或语义规则与一个产生式相联,只引用该产生式左端或右端的终结符或非终结符相联的属性。 属性文法的例子 设表达式为3*5+4,则语义动作打印数值19 . 中间代码的形式 1. 逆波兰式 2. 三元式、间接三元式和树形表示 3. 四元式 表达式的表示方法 1. 中缀表达式(一般表达式):运算符放在运算量之间。A+B A*B 2. 前缀表达式(波兰表达式):运算符放在运算量前面。+AB *AB 3. 后缀表达式(逆波兰表达式):运算符放在运算量后面。AB+ AB* 上述三种方法的比较 三种方法的共同点: 1. 运算量个数不变,顺序也不变。 2. 运算符个数不变。 逆波兰式的优点: 1. 是一个无括号表达式。 2. 逆波兰式的运算符出现的顺序就是原表达式的运算顺序,因而计算方便。 举例 1. ( a * b + c ) * d + b * ( a + d * c ) a b * c + d * b a d c * + * + 2. 赋值语句的后缀式 A:=B+C ABC+:= 三元式 组成:
您可能关注的文档
- 营业部绩优人员培养-定稿.ppt
- 营业部经营管理心得.ppt
- 赢得客户忠诚的五个关键.ppt
- 赢在顾客价值的服务...ppt
- 影像学正常变异.ppt
- 应变能与余能.ppt
- 应对雾霾_保护健康.ppt
- 应力与应变间的关系.ppt
- 应有格物致知的精神.ppt
- 硬件基础上课用.ppt
- 2024年云南省思茅市企业人力资源管理师之一级人力资源管理师考试完整版【含答案】.docx
- 2024年云南省怒江傈僳族自治州企业人力资源管理师之四级人力资源管理师考试完整题库及答案(名校卷).docx
- 2024年云南省临沧地区企业人力资源管理师之一级人力资源管理师考试通关秘籍题库【真题汇编】.docx
- 2024年云南省德宏傣族景颇族自治州企业人力资源管理师之一级人力资源管理师考试通关秘籍题库附答案【基.docx
- 2024年云南省德宏傣族景颇族自治州企业人力资源管理师之一级人力资源管理师考试优选题库【精选题】.docx
- 门窗安装合同范本(三)与门窗安装安全协议书 .pdf
- 雷帕霉素诱导细胞自噬在衰老相关疾病中的作用 .pdf
- 学校开展结核病防控工作督导表(共五篇) .pdf
- 学校推广普通话宣传周活动总结5篇(校园推广普通话活动总结) .pdf
- 安全检查测试工具配备管理制度(4篇) .pdf
最近下载
- 2022年考博英语-中国艺术研究院考前模拟强化练习题74(附答案详解).docx VIP
- 山东淄博卷(“暖”起来;从“阅”到乐,悦,跃,月,钥,越……)-2024年中考语文作文真题解读.docx
- 省级优秀课件人教版数学四年级上册第8单元数学广角——优化.pptx
- 四川省成都市2023-2024学年度上学期期末考试高一语文试题(解析版).doc VIP
- 第8课 第一次世界大战(导图上课)公开课教案教学设计课件资料.pptx VIP
- 全自动凯氏定氮仪的工作原理及操作流程.pdf
- 2024中小学校公开招聘简章.pdf
- GB 1499.2-2024钢筋混凝土用钢 第2部分:热轧带肋钢筋-副本.pdf
- 学堂在线海上求生与救生期末考试答案.docx
- 小学美术手工《折纸》ppt课件.pptx
文档评论(0)