- 1、本文档共31页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第四章 语义分析和中间代码生成 4.1 完成下列选择题: (1) 四元式之间的联系是通过 实现的。 a. 指示器 b. 临时变量 c. 符号表 d. 程序变量 (2) 间接三元式表示法的优点为 。 a. 采用间接码表,便于优化处理 b. 节省存储空间,不便于表的修改 c. 便于优化处理,节省存储空间 d. 节省存储空间,不便于优化处理 (3) 表达式(┐A∨B)∧(C∨D)的逆波兰表示为 。 a. ┐AB∨∧CD∨ b. A┐B∨CD∨∧ c. AB∨┐CD∨∧ d. A┐B∨∧CD∨ (4) 有一语法制导翻译如下所示: 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) b (2) a (3) b (4) b 4.2 何谓“语法制导翻译”?试给出用语法制导翻译生成中间代码的要点,并用一简例予以说明。 【解答】 语法制导翻译(SDTS)直观上说就是为每个产生式配上一个翻译子程序(称语义动作或语义子程序),并且在语法分析的同时执行这些子程序。也即在语法分析过程中,当一个产生式获得匹配(对于自上而下分析)或用于归约(对于自下而上分析)时,此产生式相应的语义子程序进入工作,完成既定的翻译任务。 用语法制导翻译(SDTS)生成中间代码的要点如下: (1) 按语法成分的实际处理顺序生成,即按语义要求生成中间代码。 (2) 注意地址返填问题。 (3) 不要遗漏必要的处理,如无条件跳转等。 例如下面的程序段: if (i0) a=i+e-b*d; else a=0; 在生成中间代码时,条件“i0”为假的转移地址无法确定,而要等到处理“else”时方可确定,这时就存在一个地址返填问题。此外,按语义要求,当处理完(i0)后的语句(即“i0”为真时执行的语句)时,则应转出当前的if语句,也即此时应加入一条无条件跳转指令,并且这个转移地址也需要待处理完else之后的语句后方可获得,就是说同样存在着地址返填问题。对于赋值语句a=i+e-b*d,其处理顺序(也即生成中间代码顺序)是先生成i+e的代码,再生成b*d的中间代码,最后才产生“-”运算的中间代码,这种顺序不能颠倒。 4.3 令S.val为文法G[S]生成的二进制数的值,例如对输入串101.101,则S.val=5.625。按照语法制导翻译方法的思想,给出计算S.val的相应的语义规则,G(S)如下: G[S]: S→L.L|L L→LB|B B→0|1 【解答】 计算S.val的文法G′[S]及语义动作如下: 产生式 语义动作 G′[S]:S′→S {print(S.val)} S→L1·L2 {S.val:=L1.val + L2.val/2L2.length} S→L { S.val:=L.val } L→L1B {L.val:=L1.val*2 + B.val L.length:=L1.length +1} L→B {L.val:=B.val L.length:=2} B→1 {B.val:=1} B→0 {B.val:=0} 4.4 下面的文法生成变量的类型说明: D→id L L→,id L|:T T→integer|real 试构造一个翻译方案,仅使用综合属性,把每个标识符的类型填入符号表中(对所用到的过程,仅说明功能即可,不必具体写出)。 【解答】 此题只需要对说
您可能关注的文档
- 肺部疾病-外科学课件11.ppt
- 肽素乳营养成分解析11.pptx
- 肽链生物合成后的加工和靶向运输.pptx
- 肺间质性病变的影像表现.ppt
- 肾上腺肿块MR的特征及诊断11.ppt
- 肾出血临床分析及处理11.ppt
- 肾功能衰竭治疗新观点新进展11.ppt
- 肾功能估算公式及慢性肾损药物剂量调整策略11.ppt
- 肾性贫血及促红素的应用11.ppt
- 肾性贫血治疗指南11.ppt
- 医院保洁岗位院感防控知识考核试卷试题(+答案)三套.docx
- 高等教育自学考试《马克思主义基本原理概论》考试测试题题库一.docx
- 教师资格证中学综合素质试题.docx
- 《蒋勋说宋词》试题及答案(推荐).docx
- 人美版美术四上《亲亲密密一家子》课件 .ppt
- 吉林省长春市五中2026届高二数学第一学期期末统考模拟试题含解析.doc
- 理论内涵、生成逻辑与实践路径:新时代社会治理共同体构建的三维图景.pdf
- 云南省玉溪市师院附中2026届数学高二上期末预测试题含解析.doc
- 护理查房甲状腺疾病护理PPT课件.pptx
- 全国20257月高等教育自学考试思想道德修养与法律基础试题(+答案)【推荐】.docx
文档评论(0)