【注】文法分析就是语法分析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(