使用lex / yacc编写C编译器需要多少时间?
在哪里可以开始吗?
解决方法
有很多解析规则不能被bison / yacc解析器解析(例如,在某些情况下区分声明和函数调用)。另外有时令牌的解释需要来自解析器的输入,特别是在C 0x中。字符序列的处理>>例如,至关重要地依赖于解析语境。
这两个工具对于解析C是非常糟糕的选择,您将不得不放弃许多特殊情况,逃避了这些工具依赖的基本框架,以正确解析C。这将需要很长时间,即使这样你的解析器可能会有奇怪的错误。
yacc和bison是LALR(1)解析器生成器,它们不够复杂,无法有效地处理C。正如其他人所指出的,大多数C编译器现在使用了一个recursive descent解析器,还有几个其他的答案已经指出了编写你自己的很好的解决方案。
C模板对于处理字符串是不利的,即使是常量的(尽管这可能在C 0x中修复,我还没有仔细研究),但是如果是这样,你可以很容易地用C模板语言编写递归下降解析器。我觉得相当有趣