В ниже программы, я намереваюсь считать каждую строку в файле в строку, сломать строку и отобразить отдельные слова. Проблема, с которой я сталкиваюсь, программа теперь выводы только первая строка в файле. Я не понимаю, почему это происходит?
#include<iostream>
#include<string>
#include<fstream>
#include<cstdio>
using namespace std;
int main()
{
ifstream InputFile("hello.txt") ;
string store ;
char * token;
while(getline(InputFile,store))
{
cout<<as<<endl;
token = strtok(&store[0]," ");
cout<<token;
while(token!=NULL)
{
token = strtok(NULL," ");
cout<<token<<" ";
}
}
}
Я новичок в C ++, но я думаю, что альтернативным подходом может быть:
while(getline(InputFile, store))
{
stringstream line(store); // include <sstream>
string token;
while (line >> token)
{
cout << "Token: " << token << endl;
}
}
Это будет анализировать ваш файл построчно и токенизировать каждую строку на основе разделения пробелов (так что это включает больше, чем просто пробелы, такие как табуляции и новые строки).
Что ж, здесь проблема. strtok ()
принимает строку с завершающим нулем, и содержимое std :: string
не обязательно заканчивается нулем.
Вы можете получить строку с завершающим нулем из std :: string
, вызвав для нее c_str ()
, но это вернет const char *
(т.е. строка не может быть изменена). strtok ()
принимает char *
и изменяет строку при ее вызове.
Если вы действительно хотите использовать strtok ()
, то, на мой взгляд, самым лучшим вариантом было бы скопировать символы из std :: string
в std :: vector
и завершающий вектор нулем:
std::string s("hello, world");
std::vector<char> v(s.begin(), s.end());
v.push_back('\0');
Теперь вы можете использовать содержимое вектора как строку с завершающим нулем (используя & v [0]
) и передать его в strtok ()
.
Если вы можете использовать Boost, я бы рекомендовал использовать Boost Tokenizer . Он предоставляет очень чистый интерфейс для токенизации строки.
То, что говорит Джеймс МакНеллис, верно.
Для быстрого решения (хотя и не лучшего) вместо
string store
используйте
const int MAX_SIZE_LINE = 1024; //or whatever value you consider safest in your context.
char store[MAX_SIZE_LINE];