可以使用Spirit(Boost C库的一部分)来解析来自流的二进制数据吗?例如,它可以用于将来自套接字的数据解析为结构,字节和单个位标志吗?谢谢!
解决方法
Boost Spirit允许使用
Extended Backus–Naur Form (EBNF)语法使用
template meta-programming定义解析器.它非常灵活,在解析过程的所有阶段都可以自定义抽象类.为了处理二进制数据流,您需要实现自定义扫描程序类,因为默认类型是为文本输入定制的.您可以在
Spirit User’s Guide的
The Scanner and Parsing部分进一步阅读.
在我看来,二进制数据流最好用手卷序列化代码处理.精神更倾向于使用标记语言或脚本语言等格式良好的语法.例如,EBNF中提供了The Complete Syntax of Lua.因此,使用Spirit构建自定义解析器可能是有意义的.另一方面,如果context-free grammar甚至存在EBNF,那么具有同步字节和CRC包围消息的专有串行数据链路将需要更多的工作来定义EBNF.
附录
The latest version of Boost Spirit includes functionality for dealing with binary data.