我有一个包含boost :: tokenizer的类的简单代码示例。
MyTokenizer.h
#pragma once
#include <iostream>
#include <boost/tokenizer.hpp>
class MyTokenizer
{
public:
typedef boost::tokenizer< boost::escaped_list_separator<char> > TokType;
MyTokenizer(std::string);
~MyTokenizer() {};
void printTok();
private:
const TokType tok_;
};
MyTokenizer.cpp
#include "MyTokenizer.h"
MyTokenizer::MyTokenizer(std::string input) :
tok_(input)
{
std::cout << "Created tokenizer from: " << input << std::endl;
for (TokType::iterator it = tok_.begin(); it != tok_.end(); ++it){
std::cout << *it << std::endl;
}
}
void MyTokenizer::printTok(){
std::cout << "printing tokens" << std::endl;
for (TokType::iterator it = tok_.begin(); it != tok_.end(); ++it){
std::cout << *it << std::endl;
}
}
的main.cpp
#include "MyTokenizer.h"
int main(void){
std::string input("a,b,c");
MyTokenizer tok(input);
tok.printTok();
}
当我运行这个例子时,它通过构造函数很好,在循环中打印预期的标记但是在调用printTok()时它会给出这个错误
似乎我无法在构造函数之外创建MyTokenizer的迭代器。
修改
我将printTok()方法更改为更简单,同时仍然抛出相同的错误,现在看起来像这样。
void MyTokenizer::printTok(){
TokType::iterator it = tok_.begin();
}
答案 0 :(得分:1)
好的我自己解决了这个问题。问题是我构建我的tokenizer的字符串在构造函数的末尾被解除分配。我通过在我的类中存储输入字符串的副本并从该字符串构建我的tokenizer来修复它。