我将构建一个lexer和一个解析器。我的问题是如何建造它们。我可以想到两个实现:
哪种实现更好?
发布于 2013-09-23 12:46:26
两者都是可行的。#1更适合调试,因为您可以保存数组并同时查看它。#2提供了更高的性能,因为它是一种单程策略,具有潜在的O(1)存储复杂性。
如果你不知道该怎么做,最好还是坚持第一条。
发布于 2013-09-23 12:57:14
2号。
用令牌迭代器编写解析器,并在令牌迭代器的operator++中实现词法。这是Boost.Spirit的方法。另外,如果你的词法足够简单,你可以使用Boost.Tokenizer (或者围绕它封装一点逻辑)。
https://stackoverflow.com/questions/18959567
复制相似问题