c – 可以使用Boost Spirit来解析字节流数据吗?

前端之家收集整理的这篇文章主要介绍了c – 可以使用Boost Spirit来解析字节流数据吗?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
可以使用Spirit(Boost C库的一部分)来解析来自流的二进制数据吗?例如,它可以用于将来自套接字的数据解析为结构,字节和单个位标志吗?谢谢!

解决方法

Boost Spirit允许使用 Extended Backus–Naur Form (EBNF)语法使用 template meta-programming定义解析器.它非常灵活,在解析过程的所有阶段都可以自定义抽象类.为了处理二进制数据流,您需要实现自定义扫描程序类,因为默认类型是为文本输入定制的.您可以在 Spirit User’s GuideThe 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.

猜你在找的C&C++相关文章