【发布时间】:2011-07-29 13:50:22
【问题描述】:
我正在尝试使用我在另一台计算机上编写的一些代码,将字符串拆分为标记。这段代码编译得很好。该代码也可以在其他一些计算机上按预期工作。我设法将代码减少到以下内容:
#include <string>
#include <boost/regex.hpp>
typedef std::vector<std::string> token_t ;
token_t generate_tokens(std::string raw_input){
//this function breaks a input string into tokens. So test 100 goes to 2 tokens "test" and "100".
boost::regex re_splitter("\\s+"); //this uses the regex \s+ to find whitespace. The + finds one or more whitespace characters.
boost::sregex_token_iterator iter(raw_input.begin(), raw_input.end(), re_splitter, -1);
//this breaks the string using the regex re_splitter to split into tokens when that is found.
boost::sregex_token_iterator j; //This is actually in the Boost examples, j is the equivalent of end. Yes this did also seem weird to me at first...
token_t token_vector;
unsigned int count = 0;
while(iter != j)
{
token_vector.push_back(*iter);
std::cout << *iter++ << std::endl;
++count;
}
return token_vector;
}
int main(){
std::string in;
int amount = -1;
std::cout << "action: ";
std::getline(std::cin, in);
boost::regex EXPR("^test \\d*(\\.\\d{1,2})?$");
bool format_matches = boost::regex_match(in, EXPR);
token_t tokens = generate_tokens(in);
if(format_matches){
amount = atoi(tokens.at(1).c_str());
}
std::cout << "amount: " << amount << "\n";
return 0;
}
编译时没有错误或警告使用:g++ -Wall test.cpp -lboost_regex
但是在运行时提供输入test 100 时,程序会失败。
动作:测试 100
a.out: /usr/local/include/boost/smart_ptr/shared_ptr.hpp:412: typename boost::detail::shared_ptr_traits::reference boost::shared_ptr::operator*() const [with T = boost::regex_traits_wrapper > >]: 断言 `px != 0' 失败。
中止
我完全不知道这里发生了什么。这是我的代码或库中的错误吗?非常感谢任何有关调试的建议!
【问题讨论】:
-
你使用的是什么版本的 boost?该代码和输入在 MSVC 2010 SP1 和 Boost 1.46.1 上运行良好