После компиляции кода происходит сбой (не могу понять почему)

введите описание изображения здесьКогда я использую функцию 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';
}

}

-3

Решение

Буфер слишком мал, чтобы содержать строку, содержащую завершающий символ 0.

+ Изменить

char * buffer = new char[ strlen( inStr.c_str() ) ];

в

char * buffer = new char[ strlen( inStr.c_str() ) + 1];

И не звони delete на указатели вы не сделали new (Удалить delete[] comp).

На самом деле, я бы никогда не использовал strtok в C ++.

1

Другие решения


По вопросам рекламы [email protected]