编译原理之自顶向下分析

原创 2005年04月26日 14:37:00

                 编译原理之自顶向下分析(daywolf原创)

       自顶向下分析算法通过最左推导中描叙出各个步骤来分析记号串输入,一般用递归下降分析和LL(1)分析。其中LL(1)分析表示从左向右地处理输入,它为输入串描述一个最左推导,只用一个符号来预测分析的方向。现在在一般的程序里都是使用LL(1)分析方法,我们在这里就只介绍LL(1)。
    LL(1)由于并没有使用递归的方法,所以必须使用分析栈。这里有一个问题不知道大家有没有注意?栈究竟用几个才是适合呢?如果是LL(1)的话就应该使用一个,如果是LL(2)的话就应该使用两个,如此类推。我们先介绍自顶向下方法中的两个动作,第一个是生成,英文是generate,第二个是匹配。我们这里不作任何的解释,实际行动最重要,哈哈。好,请看下面的例子。
    有一个简单的文法:S->aS|b,其中e标识为空
 分析栈  输入  动作
1 $               ab$             生成S->aS
2       $Sa             ab$             匹配
3       $S              b$              生成S->b
4       $b              b$              匹配
5       $               $               接收

    看到了没有,是不是很简单呢?解释一下,分析栈要先放进一个$符号标识结束,生成了之后要把内容以相反的方向压进栈。
    由于左递归是很难做出算法的,下面我们来看看用LL(1)是怎样消除左递归的。什么?不知道左递归是什么。好吧,让我告诉你,例如有这样的文法A->Aa|b,你看一下会生成什么b,ba,baa,baaa....当然还有更复杂的,不用急下面会慢慢介绍。这个简单的左递归可以转化为右递归
    A -> BA'
    A'-> aA'|e
上面的是简单的直接左递归,当然还有普遍的直接左递归,文法为A->Aa1|Aa2|...|b1|b2
转化为
    A ->  B1A'|B2A'|...BmA'
    A'->  a1A'|a2A'|...|e
还有一般的左递归,是指不带e产生式且不带有循环的文法,由于一般程序设计中不会出现在这里就不作介绍了。如果想再学习可以参Principles and Practice一书。
    你有没有发现我们只说了左递归的情况,那右递归又有没有什么消除方法呢?答案是有的。例如下面的一个例子是如下:A->ab|ar
     很明显,LL(1)分析方法不能区分这种情况中的产生式选择。这种简单揭发式将左边的a分解出来,我们称为提取左因子,结果如下。
              A ->aA'
              A'->b|r

     哇,我介绍了很多啦,有没有什么奖励啦?哈哈。其他就要自己动手咯。

编译原理之自顶向下语法分析方法

确定的自顶向下分析方法;FIRST(A);FOLLOW(A);SELECT(A->a);左递归;
  • wygwzh
  • wygwzh
  • 2017年06月12日 23:55
  • 648

语法分析笔记自顶向下分析

进行完词法分析紧接着进入语法分析阶段。语法分析判断一个句子是否合乎语言的文法规则,语法分析阶段的数学元素为:           终结符:数字(1~9),字母(a~z),运算符等字(+ - x /)符...

文法分析小结:自底向上的分析方法和自顶向下的分析方法有哪些

自底向上的分析技术 有: ( 1 )简单优先分析法 ( 2 )算符优先分析法 ( 3 )优先函数 ( 4 ) LR 分析法 首先注意一点:无论是那种语法分析,语法都是从左至右的读入符号!  自底向上分...

编译原理结构框架4自顶向下的语法分析

第四章 自顶向下的语法分析 重点:自顶向下分析的基本思想,预测分析器总体结构,预测分析表的构造,递归下降分析法基本思想,简单算术表达式的递归下降分析器。 难点:FIRST 和FOLLOW 集的...
  • hit_rxz
  • hit_rxz
  • 2014年12月02日 12:58
  • 846

不确定的自顶向下的分析思想和确定的自顶向下的分析方法

在前面可以看出,可以根据当前文法不满足LL(1)时,则不能用确定的自顶向下分析,但在这种情况下,可用不确定自顶向下的分析法,也就是说带回溯的自顶向下的分析法。引起回溯的原因是在文法中当关于某个非终结符...

实验二——自顶向下分析方法之表驱动LL(1)分析程序

自顶向下分析方法之表驱动LL(1)分析程序分为三个部分: 非LL(1)文法转换为LL(1)文法; LL(1)文法的判别; 构造预测分析表和对输入符号串进行分析。 程序流程图:非LL(1)文法转换为LL...

编译原理之表达式语法分析(一)——自顶向下

表达式语法分析

自顶向下的语法分析LL(1)

自顶向下的语法分析即是将输入词素从树的根节点开始,按照先根顺序开始创建语法树的各个结点,也是寻找输入串的最左推导的过程。 常见的递归下降就是自顶向下语法分析机制的一种,lcc就是使用这种机制,但是这...
  • jinnlxl
  • jinnlxl
  • 2015年01月01日 19:35
  • 1009

Delphi7高级应用开发随书源码

  • 2003年04月30日 00:00
  • 676KB
  • 下载

自顶向下的语法分析(修改)

自顶向下语法分析可以被看作是为输入串构造语法分析树的问题,它从语法分析树的根结点开始 ,按照先序遍历创建这棵语法分析树的各个结点。自顶向下语法分析也可以被看作寻找输入串的最左推导的过程。 ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:编译原理之自顶向下分析
举报原因:
原因补充:

(最多只允许输入30个字)