Когда я использую функцию StrSplit с постоянной строкой, она отлично работает. но когда я читаю строку из файла и затем использую ее как строку для функции StrSplit, моя программа падает. Ниже приведен код и снимок экрана с ошибкой.
string Read_from_file(){
//load the text file and put it into a single string:
std::ifstream in("test.txt");
std::stringstream buffer;
buffer << in.rdbuf();
std::string test = buffer.str();
std::cout << test << std::endl << std::endl;
return test;
}
// split the given string according to give delimeters
vector<string> &StrSplit( string inStr, string sepStr, vector<string> &outStrVec) {
char * comp;
char * buffer = new char[ strlen( inStr.c_str() ) ];
strcpy( buffer, inStr.c_str() );
comp = strtok ( buffer, sepStr.c_str() );
while ( comp != NULL ) {
outStrVec.push_back(comp);
comp = strtok ( NULL, sepStr.c_str() );
}
delete[] comp;
delete[] buffer;
return outStrVec;
}
vector<string> StrSplit( string inStr, string sepStr ) {
vector<string> outStrVec;
return StrSplit( inStr, sepStr, outStrVec );
![enter image description here][2]}
int main( ) {
Read_from_file();
string fileinput = Read_from_file();
vector<string> v;
string inStr = fileinput;
v = StrSplit( inStr, "|#$ *@.&\"!^01" );
for (unsigned int i = 0; i < v.size(); ++i) {
cout << v[i] << '\n';
}
}
Буфер слишком мал, чтобы содержать строку, содержащую завершающий символ 0.
+ Изменить
char * buffer = new char[ strlen( inStr.c_str() ) ];
в
char * buffer = new char[ strlen( inStr.c_str() ) + 1];
И не звони delete
на указатели вы не сделали new
(Удалить delete[] comp
).
На самом деле, я бы никогда не использовал strtok
в C ++.