首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Lexer和Parser

Lexer和Parser
EN

Stack Overflow用户
提问于 2013-09-23 12:43:49
回答 2查看 202关注 0票数 1

我将构建一个lexer和一个解析器。我的问题是如何建造它们。我可以想到两个实现:

  1. Lexer将把整个输入字符串转换为一个令牌数组。然后解析器就会调用这个数组。
  2. 同时进行词汇分析和句法分析。解析过程中,解析器将为nextToken调用lexer。

哪种实现更好?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-09-23 12:46:26

两者都是可行的。#1更适合调试,因为您可以保存数组并同时查看它。#2提供了更高的性能,因为它是一种单程策略,具有潜在的O(1)存储复杂性。

如果你不知道该怎么做,最好还是坚持第一条。

票数 1
EN

Stack Overflow用户

发布于 2013-09-23 12:57:14

2号。

用令牌迭代器编写解析器,并在令牌迭代器的operator++中实现词法。这是Boost.Spirit的方法。另外,如果你的词法足够简单,你可以使用Boost.Tokenizer (或者围绕它封装一点逻辑)。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/18959567

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档