我正在将一些旧的 Boost 正则表达式代码转换为 C++11,我偶然发现了我的一个测试用例的问题。这是一个使用 std::regex 导致堆栈溢出异常的场景,但使用 boost::regex 可以正常工作。我没有更改正则表达式模式,并验证了该模式是我想要的。似乎这个特定的字符串输入片段导致堆栈溢出。使用 VS2012,x64 调试构建:
std::regex regx( "(^|\\})(([^\\{:])+:)+([^\\{]*\\{)" );
const std::string testinput = " COLOR: #000; BACKGROUND-COLOR: #FFF; FONT-FAMILY: VERDANA, ARIAL, HELVETICA, SANS-SERIF; BACKGROUND:URL(URL(___FOO___)); BACKGROUND-2:URL(URL(___FOO___)); BORDER: 0 0 0 0; BORDER-2: 0 0 0; BORDER-3: 0 0; BORDER-4: 0PX; BORDER-5: 0.6; FILTER:PROGID:DXIMAGETRANSFORM.MICROSOFT.ALPHA(OPACITY=100); } ";
std::smatch what;
// this next line causes a stack overflow
std::regex_search( testinput.cbegin(), testinput.cend(), what, regx );
查看异常后的调用堆栈,正则表达式实现中似乎存在某种类型的无限递归。我目前没有 GCC 来测试这个。我究竟做错了什么?
更新:在下面的建议之后,我将此代码粘贴到控制台应用程序 VS 2012 x64 调试中,我得到了堆栈溢出。如果我将它更改为 x64 版本,或者 Win32 调试或发布它运行良好。啊???我是否需要重新安装 VS 和/或平台 SDK?我在Win7 x64上。
更新#2:有点相关的帖子: 为什么 std::regex_iterator 会导致此数据的堆栈溢出? 我想如果我重写我的正则表达式,它可能会有所帮助。我仍然不确定为什么位数很重要。以及为什么它适用于其他人,但不适用于我的系统。叹。