语法制导翻译和中间代码的生成.pptxVIP

  1. 1、本文档共50页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
编译程序的任务: 是把源程序翻译成目标程序,这个 目标程序必须和源程序的语义等同 ,也就是说,尽管它们的语法结构 完全不同,但它们所表达的结果应 完全相同。;通常,在词法分析程序和语法分析程序对 源程序的语法结构进行分析之后,要么由 语法分析程序直接调用相应的语义子程序 进行语义处理,要么首先生成语法树或该 结构的某种表示,再进行语义处理。 ;语义处理的两个功能: 第一,审查每个语法结构的静态语义, 即验证语法结构合法的程序是否真正有意义 。有时把这个工作称为静态语义分析或静态 审查。 第二,如果静态语义正确,语义处理则 要执行真正的翻译,即,要么生成程序的一 种中间表示形式(中间代码),要么生成实 际的目标代码。 ; 1.属性文法 2.语法制导翻译 3.中间代码的形式 4.简单的赋值语句的翻译 5.布尔表达式的翻译(*) ;属性文法 : 一个属性文法是一个三元组A=(G,V,F), (1) 一个上下文无关文法G; (2)一个属性的有穷集V; (3)关于属性的断言或谓词的有穷集F。 每个属性与文法的某个非终结符或终结符 相联。每个断言与文法的某产生式相联。 ;如果对G中的某一输入串而言,句子A中的所 有断言对该输入串的语法树结点的属性全 为真,则该串A是语言中的句子,编译程序 的静态语义审查工作就是验证关于所编译 的程序的断言是否全部为真。 ;;;例8.1 简单算术表达式求值的语义描述。 产生式 语义规则 (0)L→E print(E.val) (1)E→E1+T E.val:=E.val+T.val (2)E→T E.val:=T.val (3)T→T1*F T.Val:=T1.val*F.val (4)T→F T.val:=F.val (5)F→(E) F.Val:=E.val (6)F→digit F.val=digit·lexval ;例8.2 描述说明语句中各种变量的类型信息 的语义规则。 产生式 语义规则 (1)D→TL L.in:=T.type (2)T→int T.type:=Integer (3)T→real T.type:=real L1.in:=L.in (4)L→L1,id addtype(id.entry,L.in) (5)L→id addtype(id.entry,L.in) ;根据每个产生式所对应的语义子程序 (或语义规则描述的语义动作)进行 翻译的办法称作语法???导翻译。 两个主要任务: (1).简单算数术表达式计算它的值, (2).其它语法结构翻印成中间代码 ;假定我们现在要分析的语法成分是简单算术表达 式,所完成的语义处理不是将它翻译成中间代码 或是目标代码,而是计算表达式的值. 产生式 语义规则 (0)L→E print(E.val) (1)E→E1+T E.val:=E.val+T.val (2)E→T E.val:=T.val (3)T→T1*F T.Val:=T1.val*F.val (4)T→F T.val:=F.val (5)F→(E) F.Val:=E.val (6)F→digit F.val=digit·lexval;; 1).逆波兰记号 2).三元式 3).树形表示 4).四元式 ;表示规则:运算对象写在前面,运算符写在后面; 最大的优点:易于用栈结构分析表达式 ,每碰到运算对象就把他推进栈,碰到运算 符,若该运算符是二元的实施运算,并将结 果代替这两个运算对象进栈,若是一元的, 则对栈顶的元素运算,并将结果代替该运算 对象进栈,最后结果留在栈顶。;例:将-B+C*D写成逆波兰记号,并分析的计算过程 逆波兰记号:B-CD*+ 过程:1.B进栈 2.对栈顶的元素实施一元运算,并将 结果代替栈顶,即-B进栈 3.C进栈 4.D进栈 5.栈顶两元素相乘C D出栈,相乘结果进栈 6.栈顶两

文档评论(0)

SYWL2019 + 关注
官方认证
文档贡献者

权威、专业、丰富

认证主体四川尚阅网络信息科技有限公司
IP属地北京
统一社会信用代码/组织机构代码
91510100MA6716HC2Y

1亿VIP精品文档

相关文档