编译原理复习——文法grammar

【注】文法分析就是语法分析syntax analysis/parsing

【key】解析树(parsing tree/syntax tree语法分析树)、CFG(context-free grammar)

【小结】(1)把文法规则转化为解析的代码的方法:①自顶向下解析②自底向上解析

(2)解析的任务:

①根据扫描器产生的分词决定一个程序的语法结构

②显示或隐式地构造能够展示这个结构的语法树/解析树

③处理错误

即解析的输入是扫描器得到的tokens,输出是语法树

1.语法分析就是用一个结构高效表达由tokens描述的语法结构(解释这些tokens

意味着什么),且判断是否符合语法,并进行修正。

2.scanning v.s. parsing

(1)任务:扫描的任务是决定tokens的结构;解析的任务决定一个程序的语法或结构

(2)描述工具:扫描的工具是RE;解析的工具是CFG

(3)算法方法:扫描的方法是用DFA展示;解析是自顶向下解析、自底向上解析

(4)结果数据的结构:扫描的结果数据的结构是线性结构;解析的结果数据的结构是解析树parsing tree/语法树syntax tree(递归)

3.R.E. v.s. CFG

上下文无关文法是递归的,CFG表达能力强于R.E(∵R.E无法描述含有相同数量某字符的分词,而CFG可以)

一、CFG

  • 14
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值