Использовать std :: getline вместо оператора >> (std :: istream, int)
std::istream infile(stuff);
std::string line;
while(std::getline(infile, line)) {
int result;
result = atoi(line.c_str());
if (result)
std::cout << result;
}
Причина, по которой вы испытываете такое поведение, заключается в том, что когда std :: istream пытается (и не может) прочитать целое число, он устанавливает флаг "badbit", который означает, что что-то пошло не так. Пока этот флаг битника остается установленным, он вообще ничего не будет делать. Так что на самом деле это не перечитывание в этой строке, это не делает НИЧЕГО, и оставляет ценность, которая была там одна. Если вы хотите больше соответствовать тому, что у вас уже было, это, вероятно, как показано ниже. Приведенный выше код проще и менее подвержен ошибкам.
std::istream infile(stuff);
int result;
infile >> result; //read first line
while (infile.eof() == false) { //until end of file
if (infile.good()) { //make sure we actually read something
std::cout << result;
} else
infile.clear(); //if not, reset the flag, which should hopefully
// skip the problem. NOTE: if the number is REALLY
// big, you may read in the second half of the
// number as the next line!
infile >> result; //read next line
}