编译原理 第六章 算符优先分析法_第1页
编译原理 第六章 算符优先分析法_第2页
编译原理 第六章 算符优先分析法_第3页
编译原理 第六章 算符优先分析法_第4页
编译原理 第六章 算符优先分析法_第5页
已阅读5页,还剩1页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

本文格式为Word版,下载可任意编辑——编译原理第六章算符优先分析法第6章自底向上优先分析

第六章算符优先分析法

课前索引

什么是自下而上语法分析的策略?

什么是移进-归约分析?

移进-归约过程和自顶向下最右推导有何关系?

自下而上语法分析成功的标志是什么?

什么是可归约串?

移进-归约过程的关键问题是什么?

如何确定可归约串?

如何决定什么时候移进,什么时候归约?

什么是算符文法?什么是算符优先文法?

算符优先分析是如何识别可归约串的?

算符优先分析法的优缺点和局限性有哪些?

算符优先分析法是自下而上(自底向上)语法分析的一种,特别适应于表达式的语法分析,由于它的算法简单直观易于理解,因此,也是学习其它自下而上语法分析的基础。通过本章学习学员应把握:

对给定的文法能够判断该文法是否是算符文法

对给定的算符文法能够判断该文法是否是算符优先文法

对给定的算符文法能构造算符优先关系表,并能利用算符优先关系表判断该文法是否是算符优先文法。

能应用算符优先分析算法对给定的输入串进行移进-归约分析,在分析的每一步能确定当前应移进还是归约,并能判断所给的输入串是否是该文法的句子。

了解算符优先分析法的优缺点和实际应用中的局限性。

算符优先分析法是自下而上语法分析的一种,它的算法简单、直观、易于理解,所以寻常作为学习其它自下而上语法分析的基础。为学好本章内容,学员应复习有关语法分析的知识,如:什么是语言、文法、句子、句型、短语、简单短语、句柄、最右推导、规范归约基本概念。

通过本章学习后,学员应当能知道算符文法的形式。

对一个给定的算符文法能构造算符优先关系分析表,并能判别所给文法是否为算符优先文法。

分清规范句型的句柄和最左素短语的区别,进而分清算符优先归约和规范归约的区别。

算符优先分析的可归约串是句型的最左素短语,在分析过程中如何寻觅可归约串是算符优先分析的关键问题。对一个给定的输入串能应用算符优先关系分析表给出分析(归约)步骤,并最终判断所给输入串是否为该文法的句子。

深入理解算符优先分析法的优缺点和实际应用中的局限性。

第6章自底向上优先分析

第6章自底向上优先分析

短语、直接短语、句柄的定义:文法G[S],

SαAδ且Aβ则称β是句型αβδ相对于非终结符A的短语。若有Aβ则称β是句型αβδ相对于A或规则A→β的直接短语。一个句型的最左直接短语称为该句型的句柄。

算符优先分析法是一种自底向上分析方法,也称移进-归约分析法,粗略地说它的实现思想是对输入符号串自左向右进行扫描,并将输入符逐个移入一个后进先出栈中,边移入边分析,一旦栈顶符号串形成某个句型的句柄时,(该句柄对应某产生式的右部),就用该产生式的左部非终结符代替相应右部的文法符号串,这称为一步归约。重复这一过程直到归约到栈中只剩文法的开始符号时则为分析成功,也就确认输入串是文法的句子。本章将在介绍自底向上分析思想基础上,着重介绍算符优先分析法。

栈顶符号串是指该符号串包含栈顶符号在内,并由栈中某个符号为该符号串的头,栈顶符号为该符号串的尾,也可以只有一个栈顶符号。

6.1自底向上分析概述

自底向上分析法,也称移进-归约分析法,或自下而上分析。现举例说明。

例6.1

设文法G[S]为:(1)S→aAcBe(2)A→b(3)A→Ab(4)B→d

对输入串abbcde#进行分析,检查该符号串是否是G[S]的句子。由于自底向上分析的移进-归约过程是自顶向下最右推导的逆过程,而最右推导为规范推导,自左向右的归约过程也称规范归约。简单看出对输入串abbcde的最右推导是:

SaAcBeaAcdeaAbcdeabbcde

由此我们可以构造它的逆过程即归约过程。

先设一个先进后出的符号栈,并把句子左括号\号放入栈底,其分析过程如表6.1。

表6.1用移进-归约对输入串abbcde#的分析过程f6-1-1.swf

图6.1自底向上构造语法树的过程

第6章自底向上优先分析

推倒的逆过程为:SaAcBeaAcdeaAbcdeabbcde

对上述分析过程也可看成自底向上构造语法树的过程,每步归约都是构造一棵子树,最终当输入串终止时刚好构造出整个语法树,图6.1(a)(b)(c)(d)给出构造过程,可与表中相应分析步骤对照。

在上述移进-归约或自底向上构造语法树的过程中,我们怎么知道何时移进,何时归约,不能只简单地看成栈顶出现某一产生式的右部就可用相应产生式归约,例如在表6.1分析到第5)步时栈中的符号串是#aAb,栈顶符号串b和Ab分别是产生式(2),(3)的右部,这时终究用(2)归约还是用(3)归约是自底向上分析要解决的关键问题。

由于移进-归约是规范推导(最右推导)的逆过程,即规范归约(最左归约)。当一个文法无二义性时,那么它对一个句子的规范推导是唯一的,规范归约也必然是唯一的。因而每次归约时一定要按当前句型的句柄,也就是说,任何时候栈中的符号串和剩余的输入串组成一个句型,当句柄出现在栈顶符号串中时,则可用句柄归约,这样一直归约到输入串只剩终止符,文法符号栈中只剩开始符号。这时才能认为输入符号串是文法的句子。否则为出错。

由此可见自底向上分析的关键问题是在分析过程中如何确定句柄,也就是说如何知道何时在栈顶符号串中已形成某句型的句柄,那么就可以确定何时可以进行归约。自底向上的分析算法好多,我们仅在本章和第7章介绍目前常

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论