在http://hackingoff.com/compilers/ll-1-parser-generator上解释解析表

时间:2015-02-04 15:44:25

标签: parsing context-free-grammar ll

我在http://hackingoff.com/compilers/ll-1-parser-generator使用以下语法:

E ->  T E'
E' ->  + T E' 
E' -> EPSILON
T ->  F T'
T' -> * F T'
T' -> EPSILON 
F -> ( E ) 
F ->  id

输出解析表是

[
        [0, "+", "*", "(", ")", "id", "$"],
        [0, 0, 0, 0, 0, 0, 0],
        [0, 10, 10, 1, 9, 1, 9],
        [0, 2, 10, 10, 3, 10, 3],
        [0, 9, 10, 4, 9, 4, 9],
        [0, 6, 5, 10, 6, 10, 6],
        [0, 9, 9, 7, 9, 8, 9]
]

有人可以解释一下解析表吗?特别是,910的含义是什么,因为生产规则中只有8行

1 个答案:

答案 0 :(得分:1)

它在页面本身中解释,就在表格上方:

  

如果非终端的预测集中没有终端,则会在表中放置错误代码。如果该终端在跟随(非终端),则该错误是POP错误。否则,这是一个SCAN错误。

     

POP错误代码=预测表格产品数量+ 1

     

SCAN错误代码=预测表格产品数量+ 2

因此,对于具有八个生产规则的语法,值9和10分别为POP errorSCAN error