zoukankan      html  css  js  c++  java
  • 语法分析--自上而下分析的基本问题

    语法分析基本概念

    语法分析的前提:对语言的语法结构进行描述,采用正规式和有限自动机描述和识别语言的单词符号, 用上下文无关文法来描述语法规则

    语法分析的任务:分析一个文法的句子的结构

    语法分析器的功能 :按照文法的产生式(语言的语法规则),识别输入符号串是否为一个句子(合式程序)

    自下而上(Bottom-up):从输入串开始,逐步进行归约,直到文法的开始符号,归约:根据文法的产生式规则,把串中出现的产生式的右部替换成左部符号,从树叶节点开始,构造语法树,算符优先分析法、LR分析法

    自上而下(Top-down):从文法的开始符号出发,反复使用各种产生式,寻找"匹配"的推导,推导:根据文法的产生式规则,把串中出现的产生式的左部符号替换成右部,从树的根开始,构造语法树,递归下降分析法、预测分析程序

    自上而下分析面临的问题

    基本思想:从文法的开始符号出发,向下推导,推出句子,针对输入串,试图用一切可能的办法,从文法开始符号(根结点)出发,自上而下地为输入串建立一棵语法树

    多个产生式候选带来的问题,

    回溯问题:分析过程中,当一个非终结符用某一个候选匹配成功时,这种匹配可能是暂时的,出错时,不得不“回溯”


    文法左递归问题: 一个文法是含有左递归的,如果存在非终结符P

    • 面临的问题
      • 文法左递归问题
      • 回溯问题
    • 构造不带回溯的自上而下分析算法
      • 消除文法的左递归性
      • 消除回溯

    消除文法的左递归

    直接左递归的消除

    间接左递归的消除

    消除左递归的算法

    由于对非终结符排序的不同,最后所得的文法在形式上可能不一样。但不难证明,它们都是等价的

    消除回溯

    为了消除回溯必须保证:对文法的任何非终结符,当要它去匹配输入串时,能够根据它所面临的输入符号准确地指派它的一个候选去执行任务,并且此候选的工作结果应是确信无疑的

    FIRST和FOLLOW集合的构造

    FIRST集合

    令G是一个不含左递归的文法,对G的所有非终结符的每个候选α定义它的终结首符集FIRST(α)为:

    提取公共左因子

    FOLLOW集合

    L: 从左到右扫描输入串 L: 最左推导 1:每一步只需向前查看一个符号

    FIRST和FOLLOW集合的构造

    构造每个文法符号的FIRST集合


    构造FOLLOW(A)

    构造每个非终结符的FOLLOW集合

    对最后的FIRST、FOLLOW集合有点迷,真的有点迷,晚上不该看这个的!!o(╥﹏╥)o

  • 相关阅读:
    审核系统
    ehcache 缓存
    tomcat 内存设置
    html5 开发 跨平台 桌面应用
    service thread 结合使用
    html5桌面应用
    鼠标 事件
    服务器 判断 客户端 文件下载
    使用github管理Eclipse分布式项目开发
    uub代码
  • 原文地址:https://www.cnblogs.com/ygjzs/p/12431253.html
Copyright © 2011-2022 走看看