- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第四章 语义分析和中间代码生成 4.1 完成下列选择题: (1) 中间代码的优点是 。 A.节省存储空间 B.编译时间短 C.编译结构在逻辑上更为简单明确 D.节省内存且编译时间短 (2) 四元式之间的联系是通过 实现的。 A.指示器 B.临时变量 C.符号表 D.程序变量 (3) 间接三元式表示法的优点为 。 A.采用间接码表,便于优化处理 B.节省存储空间,不便于表的修改 C.便于优化处理,节省存储空间 D.节省存储空间,不便于优化处理 (4) 表达式(┐A∨B)∧(C∨D)的逆波兰表示为 。 A.┐AB∨∧CD∨ B.A┐B∨CD∨∧ C.AB∨┐CD∨∧ D.A┐B∨∧CD∨ (5) 后缀式________对应的中缀表达式是a-(-b)*c (注:@表示求负运算)。 A.a-b@c* B.ab@-c* C. ab-c@* D.ab@c*- (6) 后缀式ab+cd+/ 可用中缀表达式________来表示。 A.a+b/c+d B.(a+b)/(c+d) C.a+b/(c+d) D.a+b+c/d (7) 表达式(a+b)*c的后缀表达式为________。 A.ab*c+ B.abc*+ C.ab+c* D.abc+* (8) 中间代码生成时所依据的是________。 A.语法规则 B.词法规则 C.语义规则 D.等价变换规则 (9) 四元式表示法的优点为________。 A.不便于优化处理但便于表的更动 B.不便于优化处理但节省存储空间 C.便于优化处理也便于表的更动 D.便于表的更动也节省存储空间 (10) 有一语法制导翻译如下所示: S→bAb {print‘’1‘’} A→(B {print‘’2‘’} A→a {print‘’3‘’} B→Aa) {print‘’4‘’} 若输入序列为b(((aa)a)a)b,且采用自底向上的分析方法,则输出序列为 。 A B C D 【解答】 (1) 中间代码的优点是使编译结构在逻辑上更为简单明确,特别是使目标代码的优化比较容易实现。故选C。 (2) 四元式之间的联系是通过临时变量实现的。故选B。 (3) 间接三元式采用间接码表,便于优化处理。故选A。 (4) 选B。 (5) 选D。 (6) 选B。 (7) 选C。 (8) 参见第一章1.3节,中间代码生成时所依据的是语义规则。故选C。 (9) 四元式表示法的优点是既便于优化处理又便于表的更动。故选C。 (10) 句子b(((aa)a)a)b对应的语法树见图4-1,采用自底向上归约得到的输出序列为故选B。 图4-1 句子b(((aa)a)a)b对应的语法树 4.2 何谓“语法制导翻译”?试给出用语法制导翻译生成中间代码的要点,并用一简例予以说明。 【解答】 语法制导翻译(SDTS)直观上说就是为每个产生式配上一个翻译子程序(称语义动作或语义子程序),并且在语法分析的同时执行这些子程序。也即在语法分析过程中,当一个产生式获得匹配(对于自上而下分析)或用于归约(对于自下而上分析)时,此产生式相应的语义子程序进入工作,完成既定的翻译任务。 用语法制导翻译(SDTS)生成中间代码的要点如下: (1) 按语法成分的实际处理顺序生成,即按语义要求生成中间代码。 (2) 注意地址返填问题。 (3) 不要遗漏必要的处理,如无条件跳转等。 例如下面的程序段: if (i0) a=i+e-b*d; else a=0; 在生成中间代码时,条件“i0”为假的转移地址无法确定,而要等到处理“else”时方可确定,这时就存在一个地址返填问题。此外,按语义要求,当处理完(i0)后的语句(即“i0”为真时执行的语句)时,则应转出当前的if语句,也即此时应加入一条无条件跳转指令,并且这个转移地址也需要待处理完else之后的语句后方
您可能关注的文档
- 汽车构造与原理上册发动机第2版课件作者蔡兴旺主编第9章节发动机润滑系统.ppt
- 汽车电气系统结构与维修图解教程课件作者谭本忠1第一章节电源系统.ppt
- 编单片机原理与应用三版课件作者潘永雄第4-7章节第7章节.ppt
- 编码理论第二版课件作者田丽华第1-5章节第1章节.ppt
- 编码理论第二版课件作者田丽华第1-5章节第2章节.ppt
- 编码理论第二版课件作者田丽华第1-5章节第3章节.ppt
- 汽车构造与原理上册发动机第2版课件作者蔡兴旺主编第11章节新型汽车发动机.ppt
- 编码理论第二版课件作者田丽华第1-5章节第4章节.ppt
- 汽车电气系统结构与维修图解教程课件作者谭本忠2第二章节起动系统.ppt
- 编码理论第二版课件作者田丽华第6-11章节第6章节.ppt
- 汽车电器检测与维修实训课件作者董继明胡勇阴丽华模块四汽车点火系统的检修.ppt
- 编译原理教程第二版习题解析与上机指导课件作者胡元义第7-8章节.ppt
- 编译原理教程第三版课件作者胡元义全书第1章节.ppt
- 汽车电器检测与维修实训课件作者董继明胡勇阴丽华模块五汽车灯光 信号 仪表的检修.ppt
- 编译原理教程第三版课件作者胡元义全书第2章节.ppt
- 汽车电器检测与维修实训课件作者董继明胡勇阴丽华模块一汽车电器检测基础.ppt
- 汽车机械基础课件作者陈红第十章节.ppt
- 汽车电器检测与维修实训课件作者董继明胡勇阴丽华项目2_3调节器的检修.ppt
- 汽车电器检测与维修实训课件作者董继明胡勇阴丽华项目2_4充电线路的连接.ppt
- 编译原理教程第三版课件作者胡元义全书第5章节.ppt
文档评论(0)