- 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文档。上传文档
查看更多
* 第 6 讲 西北农林科技大学本科教程 主讲教师:赵建邦 第三章 语法分析 3.1 文法和语言 3.2 推导与语法树 3.3 自顶向下的语法分析 3.4 自底向上的语法分析 3.5 规范规约的自底向上语法分析方法 第三章《语法分析》 3.3 自顶向下的语法分析 递归下降分析法 LL(1)分析法(下一讲内容) 重点掌握 消除左递归 消除回溯 构建递归下降子程序 本讲目标 3.3 自顶向下的语法分析 算法思想: 从文法的开始符号出发,向下推导,如果推导出的句子恰好为输入符号串,则输入符号串为符合该文法的句子; 或者:开始符号作为根节点,向下生长出一棵语法树,其叶子节点组成的句子恰好为输入符号串。这里的每一步“生长”对应一次直接推导。 自顶向下分析方法: 1、不确定的自顶向下分析 2、确定的自顶向下分析 递归下降分析法 LL(1)分析法 1、不确定的自顶向下分析方法 假定文法G[S]为 S?→?xAy ?? A?→?ab | a 若输入串为xay,则其分析过程如下: (1)建立根节点S; (2)关于S的产生式只有一个,则生长语法树, 匹配语法树的第一个终结符x; (3) A?→?ab | a 有两个候选式,选择第一个, 并且匹配语法树的第二个叶子节点a; (4)输入串xay期待匹配y,而语法树中的b与之匹配失败; S A y a b x 3.3 自顶向下的语法分析 1、不确定的自顶向下分析方法 假定文法G[S]为 S?→?xAy ?? A?→?ab | a 若输入串为xay,则其分析过程如下: (5)撤销匹配a, 注销A所生成的子树,回溯; (6)选择产生式A?→?a,重新匹配a; (7) 匹配输入串的字符y;而语法树的最后 一个叶子节点也是y,因此语法树和输入串xay匹配成功。 S A y a b x a 3.3 自顶向下的语法分析 小结:关于不确定的自顶向下分析方法 这种自顶向下的分析是一个不断试探的过程;即,在分析过程中,如果出现多个产生式(即候选式)可供选择,则逐一试探每一候选式进行匹配,每当一次试探失败,就选取下一候选式再进行试探; 此时,必须回溯到这一次试探的初始现场,包括注销已生长的子树及将匹配指针调回到失败前的状态。 这种带回溯的自顶向下分析方法实际上是一种穷举的试探方法,其分析效率极低,在实用的编译程序中很少使用。 3.3 自顶向下的语法分析 2、确定的自顶向下分析方法 确定的自顶向下分析要求文法满足两个条件: (1) 文法不含左递归:即不存在这样的非终结符号A:有A→A…存在或者有 ; 原因:左递归的文法使自顶向下分析工作陷入无限循环 E→E+T 3.3 自顶向下的语法分析 (2) 无回溯,对文法的任一非终结符号,当其产生式右部有多个候选式可供选择时,各候选式所推出的终结符号串的首字符集合要两两不相交 原因:会导致先前做的一大堆语法工作和语义工作(指中间代码产生工作和各种表格的簿记工作)推倒重来 3、消除左递归 方法: 引入一个新的非终结符,把含有左递归的产生式改写为右递归。 设关于非终结符A的直接左递归的产生式形如 A?→?Aα | β 其中,α、β是任意的符号串且β不以A开头。该产生式所能推导的句子如下: … 3.3 自顶向下的语法分析 再看下面不含A的直接左递归的产生式: A?→?βA A →?α A | ε 这两个产生式所能推导的句子如下: 可见,两种产生式所推导的结果相同:都能描述正规表达式βα* 3.3 自顶向下的语法分析 3、消除左递归 规则:将产生式 A?→?Aα | β 改写为: A?→?βA‘ A’ →?α A‘ | ε其中, A’是新引入的非终结符。ε 不可缺少,否则推导过程无法结束。 3.3 自顶向下的语法分析 例如,含有直接左递归的表达式文法G[E]为 G[E]:E?→?E+T | T ? T?→?T*F | F F?→?(E) | i E?→?TE E?→?+TE | ε (3.2) 经过消去直接左递归后得到文法G[E]为 T?→?FT T?→?*FT | ε? ? G[E]: F?→?(E) | i 3.3 自顶向下的语法分析 3、消除左递归 一般情况下,设文
您可能关注的文档
最近下载
- 采购合同结清证明模板.doc VIP
- 对乡镇领导班子干部成员的批评意见范文.pdf VIP
- 各类骨折病人的体位护理.pptx VIP
- 机动车检测人员试题库(附答案).pdf VIP
- 2025年安徽工业经济职业技术学院单招职业技能测试题库带答案(综合题).docx VIP
- 工学院机械电子工程专业留学生培养方案.docx VIP
- 2025年湖南高速铁路职业技术学院单招职业适应性测试题库及一套完整答案.docx VIP
- 2023年蚌埠市从优秀村(社区)干部中考试录用乡镇机关公务员加分考试真题及答案.pdf VIP
- 【教学创新大赛】《数字信号处理》教学创新成果报告.docx
- 学习领会二十届中央纪委四次全会上重要讲话心得体会.docx VIP
文档评论(0)