c++ - 保存/序列化 boost 或 std 正则表达式

标签 c++ regex boost std

是否可以对文件进行序列化/反序列化和保存/加载正则表达式?

我们有一个非常耗时的过程来构建一些正则表达式,我想知道我们是否可以通过保存和加载它们来节省一些时间。

最佳答案

不,这可能是不可能的,因为无论如何都需要您重新编译正则表达式。

但是,如果您使用 boost::xpressive,您可以在编译时通过正则表达式的表达式模板构造来编译正则表达式。这将使正则表达式编译时间完全消失。

Boost Xpressive

但是,您使用过多时间的真正原因几乎可以肯定是您通过使用回溯正则表达式引擎不正确地使用了正则表达式,即 IE。

RE2是传统的自动机正则表达式引擎,不使用回溯,而是直接构造NFA或DFA。如果您不使用反向引用或许多基于非正则表达式的“功能”,使用 RE2 将显示在许多极端情况下速度 boost 一个数量级。

如果您正在使用这些功能,您应该意识到它们将严格控制您的匹配速度,而且它们几乎肯定是您试图消除的速度变慢的主要原因。

关于c++ - 保存/序列化 boost 或 std 正则表达式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18752807/

相关文章:

c++ - 初始化静态变量 : position dependent?

尽管匹配但未找到 Java 命名的捕获组

c++ - 在从磁盘写入和读取的结构中使用 std::bitset 是否可以?

c++ - Win32 - 从 C/C++ 中选择目录对话框

Javascript 替换为 $1 作为 var

c++ - g++ 中的链接问题

c++ - 从 noncopyable 派生 AbstractBaseClasses (ABC) 有缺点吗?

c++ - 通过自定义宏构造 boost::fusion::map(以及更多)

c++ - 逐 block 移动

php - Preg 匹配不以 @ 开头的模式