- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 Boost Regex。我有以下代码(简化):
bool search_for_match(const string& data)
{
boost::smatch results;
if(boost::regex_search(data, results, my_regex))
{
if(results["REVISION"].matched)
{
std::string the_submatch = results["REVISION"].str();
std::cout << the_submatch << std::endl;
}
return true;
}
return false;
}
my_regex
是一个成功编译的正则表达式。我将 the_submatch
分配给 results["SUBMATCH_TWO"].str()
的行抛出了 std::length_error
和 类型的异常>what()
打印出 basic_string::_S_create
。
阅读有关 Boost sub_match 的文档,它指出如果 matched
为真,则将设置迭代器。为什么这么火? data
字符串在这里没有超出范围,但它确实表现得像迭代器未定义或数据字符串超出范围,这使迭代器变坏了。该文档还指出,如果 matched
为 false,则只返回一个空字符串。所以,我知道 matched 必须为真,但迭代器全都乱码了。
这是正则表达式:
(?<FLIGHT_ID>[[:alnum:]]+)
\t[ ]{1,2}
(?<BEACON_CODE>[[:alnum:]]+)
\t[ ]{1,2}
((?=[A-Z]{2,5}[ ])(?<DEPARTURE_POINT>[A-Z]{2,5})[ ](?<DESTINATION_POINT>[A-Z]{2,5})|(?<DEPARTURE_POINT>[^\t ]{1,13}))
\t?[ ]{1,2}
(?<ROUTE1>[[:print:]]+)
(?: \t[ ]+ (?<EDCT>[[:alnum:]]+) )?
\r\n
(?<REVISION>\d+)?
(?: \s+ (?<STRIP_ORIGINATOR>[[:alnum:]]+) )?
\r\n
(?<AIRCRAFT_TYPE>[[:alnum:]/ ]+)
\t[ ]{1,2}
P(?<DEPARTURE_TIME>\d+)
(?: [ ][ ]\t[ ]{1,2} )?
(?: (?<ROUTE2>[[:print:]]+) )?
(?: \t[ ][ ] )?
(?: (?<EDCT_TIME>\d+) )?
\r\n
\n
(?<COMPUTER_ID>[[:alnum:]]+)
\t[ ]{1,2}
(?<ALTITUDE>VFR/\d+|\d+)
(?: [\t ]* (?<ROUTE3>[[:print:]]+) )?
\r\n?
如您所见,名为 REVISION 的子组是可选的。这就是为什么我检查 matched
是否为真。我像这样编译 my_regex
:
boost::regex my_regex;
void compile_pattern(const string& pattern)
{
try
{
boost::regex compiled_expression(pattern, boost::regex::mod_x);
my_regex = compiled_expression;
}
catch(boost::regex_error& e)
{
std::cout << e.what() << std::endl;
}
}
我读入了包含该正则表达式的整个文件并将其存储到一个字符串中并将其传递到 compile_patterns()
函数中。这似乎工作得很好,因为我没有看到抛出异常,所以它对我来说似乎是一个有效的正则表达式。
最佳答案
导致此错误的常见罪魁祸首是从 nullptr
char* 构造 std::string
时。
在您的情况下,这是不可能的,因为所有迭代器范围都表示为源字符串中的迭代器。那么,当问题出在所显示的代码之外时,似乎是最合乎逻辑的解释。
例如,您可以将对 std::string const
的陈旧引用作为 data
参数传递。这将调用 Undefined Behaviour ,可以通过多种方式体现。
将用于保存 std::string
实例的内存解释为此类对象时,当该对象不再存在(它已被破坏,或者内存甚至可能已经被重新调整用途)以生成一个取消引用空指针的迭代器。
关于c++ - Boost sub_match 抛出 std::length_error 异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48291061/
我正在使用 Boost Regex。我有以下代码(简化): bool search_for_match(const string& data) { boost::smatch results;
我将 std::sub_match 作为参数传递给 std::thread(请参阅下面的示例代码)。线程函数需要一个 const 字符串引用。 sub_match 可以转换为字符串。所以一切都可以正常
我正在阅读 std::sub_match 的文档并看到它公开继承自 std::pair .自sub_match只是一对迭代器变成了一个字符序列,加上一些额外的功能,我可以理解它是用一个pair实现的,
我想使用空白字符作为分隔符来标记 std::string,但是在一对引号之间不应考虑分隔符,也不允许使用其他引号。为此,我使用以下 regex (表示为原始字符串文字): R"((\"[^\"]*\"
我正在尝试将 std::match_results 数据映射到我的 std::multimap 变量。这是代码: #include "Precompiled.h" using namespace st
我是一名优秀的程序员,十分优秀!