1.对于典型的if-else二义性文法,存在移进-接受(移进-归约)冲突,在我的LALR分析器中采用了和YACC相同的方法,首先处理移进操作.这样就可消除if-else的二义性.
if-else文法:
S->iEStS
S->iES
S->s
E->e
说明:
i代表if
s代表stmt
e代表exp
t代表else
对于以上文法生成的LALR(1)分析表为:
data:image/s3,"s3://crabby-images/ee47e/ee47eefd1c846d3c3c51c77d510bbc4c7e0288a9" alt=""
对于if exp stmt语句分析结果为:
data:image/s3,"s3://crabby-images/42d28/42d28108295465559263fd682bed96a75bee3f11" alt=""
对于if exp stmt else stmt语句分析结果为:
data:image/s3,"s3://crabby-images/ded86/ded867b47e03eefad9f5a62344f38769af88ab71" alt=""
对于if exp if exp stmt语句分析结果为:
data:image/s3,"s3://crabby-images/9533e/9533ea1bd94b29f6fb0a4e22e911ffd6f78cfe61" alt=""
对于if exp if exp stmt else stmt语句分析结果为:
data:image/s3,"s3://crabby-images/d57ab/d57ab249c759c000bb1d7183c000f90e1b412e6f" alt=""
2.众所周知LALR文法同样存在归约-归约冲突,在我的LALR分析器中使用先书写的产生式进行归约.
对于给定的存在归约-归约冲突的文法:
S->T
S->i
T->i
生成LALR(1)分析表为:
data:image/s3,"s3://crabby-images/1974e/1974e06190667b26ebaa70ff3b94e925d5ab5b5a" alt=""
分析输入串i的过程为:
data:image/s3,"s3://crabby-images/f3203/f3203c4926468144f85e420541a2d3443acf51f3" alt=""
以上就是我的LALR(1)分析器处理冲突的方法了.
下面逐步对这个分析器进行扩充,以实现一个能自由输入文法的分析器.
posted on 2010-07-22 15:04
lwch 阅读(2035)
评论(0) 编辑 收藏 引用 所属分类:
NScript