- 1、本文档共82页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
* 2. 特点: 6.4 L-属性文法和自顶向下翻译 L-属性文法 A. 该类属性文法允许我们通过一次遍历就计算出所 有属性值. B. 可在自上而下语法分析的同时实现L-属性文法的 计算. C. S-属性文法一定是L-属性文法. * 6.4 L-属性文法和自顶向下翻译 一个非L-属性文法 产生式 语义规则 A →LM A →QR L.i=l(A.i) M.i=m(L.s) R.i=r(A.i) Q.i=q(R.s) A.s=f(Q.s) * 一. 翻译模式 1. 翻译模式的定义: 一种适合语法制导翻译的语义描述形式,给出了 使用语义规则进行计算的次序,可把某些实现细节表 示出来. 形式:在翻译模式中,和文法符号相关的属性和语义规 则,用{ }括起来,插入到产生式右部的合适位置上. 例:E →TR R →addop T { pr(addop.lex)} R1| ε T →num {pr(num.val)} 6.4 L-属性文法和自顶向下翻译 * 为每一个语义规则建立一个包含赋值的动作,并 把这个动作放在相应的产生式右边的末尾. 6.4 L-属性文法和自顶向下翻译 2. 翻译模式的设计: A. 只有综合属性时,可以按如下方式建立翻译模式: * B.若既有综合属性又有继承属性时,则按如下方式建立 翻译模式: ①产生式右边的符号的继承属性必须在这个符号以前的动作中计算出来. ②一个动作不能引用这个动作右边的符号的综合属性. ③产生式左边非终结符的综合属性只有在它所引用的所有属性都计算出来以后才能计算.计算这种属性的动作通常可放在产生式右端的末尾. 6.4 L-属性文法和自顶向下翻译 2. 翻译模式的设计: * 举例: E →TR R →addop T{pr(addop.lex)}R1|ε T →num {pr(num.val)} 输入:9-5+2 深度优先遍历后 输出:95-2+ E T R R R 9 Pr(‘9’) - T Pr(‘-’) + T Pr(‘+’) 5 Pr(‘5’) 2 Pr(‘2’) ε * 二.自顶向下翻译 1.讨论: L-属性文法在自顶向下分析中的实现 6.4 L-属性文法和自顶向下翻译 自顶向下语法分析的前提是消除文法中的左递归. * E→E1+T { E.val:=E1.val+T.val } E→E1-T { E.val:=E1.val-T.val } E→T { E.val:=T.val } T→(E) { T.val:=E.val } T→num {T.val:=num.val} E→T { R.i := T.val } R { E.val:=R.s } R→+ T { R1.i := R.i +T.val } R1 { R.s := R1.s } R→- T{ R1.i := R.i -T.val } R1 { R.s := R1.s } R→ε { R.s := R.i } T→(E) { T.val:=E.val } T→num{ T.val:=num.val } 2.例题: * 计算表达式 9-5+2 带注释语法树 i: 继承属性 s : 综合属性 E T.val=9 R.i=9 R.i=4 R.i=6 Num.val=9 - T.val=5 + T.val=2 Num.val=2 ε Num.val=5 6.4 L-属性文法和自顶向下翻译 E.val R.s R.s R.s * A→A1Y { A.a=g(A1.a ,Y.y } A→X { A.a= f (X.x) } A→X { R.i:=f (X.x) } R { A.a:=R.s } R→Y { R1.i =g (R.i, Y.y) } R1 { R.s:=R1.s } R→ε { R.s := R.i } 6.4 L-属性文法和自顶向下翻译 3. 转换左递归翻译模式的一般方法: 消除左递归前: 消除左递归后: * A.a=g(g(f(X.x),Y1.y),Y2.y) A.a=g(f(X.x),Y1.y) A.a=f(X.x) X Y2 Y1 6.4 L-属性文法和自顶向下翻译 带注释语法树 R.i=g(g(f(X.x),Y1.y),Y2.y) Y2 R.i=g(f(X.x),Y1.y) R.i=f(X.x) A X Y1 R.s R.s R.s
您可能关注的文档
- 第5章 网站的规划与设计.ppt
- 第4章 查询与修改数据2.ppt
- 新世纪中国银行体制改革及地方银行机构网点的空间分布——兼及全国性商业银行的比较.pdf
- 数据库操作及管理语言Oracle SQL视频脚本.doc
- 第4节 字符串08.pdf
- 第4节关系数据库标准语言201209.ppt
- 高考文言文命题特点及存在的问题.pdf
- CCTS 专家共识:临床试验中多重性问题统计学考虑.pdf
- 三峡工程的防洪调度运用及风险分析.pdf
- 面向构件基于与欣内核的进程_线程池原理与实现.pdf
- 数据仓库:Redshift:Redshift与BI工具集成.docx
- 数据仓库:Redshift:数据仓库原理与设计.docx
- 数据仓库:Snowflake:数据仓库成本控制与Snowflake定价策略.docx
- 大数据基础:大数据概述:大数据处理框架MapReduce.docx
- 实时计算:GoogleDataflow服务架构解析.docx
- 分布式存储系统:HDFS与MapReduce集成教程.docx
- 实时计算:Azure Stream Analytics:数据流窗口与聚合操作.docx
- 实时计算:Kafka Streams:Kafka Streams架构与原理.docx
- 实时计算:Kafka Streams:Kafka Streams连接器开发与使用.docx
- 数据仓库:BigQuery:BigQuery数据分区与索引优化.docx
文档评论(0)