C ++ сбой ifstream, почему эта строка идет не туда, куда должна?

StackOverflow https://stackoverflow.com/questions/456357

  •  19-08-2019
  •  | 
  •  

Вопрос

Я хочу, чтобы строка, отмеченная символом // ЭТА СТРОКА ДОЛЖНА БЫТЬ НАПЕЧАТАНА, делала свое дело, то есть выводила значения int между "синонимами" и "антонимами".

Это текстовый файл:

dictionary.txt

1 cute
2 hello
3 ugly
4 easy
5 difficult
6 tired
7 beautiful
synonyms
1 7
7 1
antonyms
1 3
3 1 7
4 5
5 4
7 3






#include <iostream>
#include <fstream>
#include <string>

#include <sstream>
#include <vector>


using namespace std;

class WordInfo{

      public:

             WordInfo(){}

             ~WordInfo() {     
             }

             int id() const {return myId;}

             void readWords(istream &in)
             {
               in>>myId>>word;     
             }


             void pushSynonyms (string synline, vector <WordInfo> wordInfoVector)

             {

             stringstream synstream(synline);

             vector<int> synsAux;

             int num;

             while (synstream >> num) synsAux.push_back(num);

              for (int i=0; i<synsAux.size(); i++){
              cout<<synsAux[i]<<endl;  //THIS LINE SHOULD BE PRINTING

             }       



             }

             void pushAntonyms (string antline, vector <WordInfo> wordInfoVector)
             {

             }

             //--dictionary output function

             void printWords (ostream &out)
             {
                out<<myId<< " "<<word;     
             }



             //--equals operator for String
             bool operator == (const string &aString)const
             {
                           return word ==aString; 

             }


             //--less than operator

             bool operator <(const WordInfo &otherWordInfo) const
             { return word<otherWordInfo.word;}

             //--more than operator

             bool operator > (const WordInfo &otherWordInfo)const
             {return word>otherWordInfo.word;}

             private:
                   vector <int> mySynonyms;
                   vector <int> myAntonyms;
                   string word;
                   int myId;


      };

      //--Definition of input operator for WordInfo
      istream & operator >>(istream &in, WordInfo &word)
      {
         word.readWords(in); 

      }



      //--Definition of output operator

      ostream & operator <<(ostream &out, WordInfo &word)
      {
            word.printWords(out);  

      }

      int main() {

          string wordFile;
          cout<<"enter name of dictionary file: ";
          getline (cin,wordFile);

          ifstream inStream (wordFile.data());

          if(!inStream.is_open())
          {
          cerr<<"cannot open "<<wordFile<<endl; 
          exit(1);                      

          }

          vector <WordInfo> wordVector; 

          WordInfo aword;



          while (inStream >>aword && (!(aword=="synonyms")))
          {
              wordVector.push_back(aword);      
          }

          int i=0;          
          while (i<wordVector.size()){
                cout<<wordVector[i]<<endl;
                i++;
                }




          vector <int> intVector;
          string aLine; //suspect


          // bad statement?
          while (getline(inStream, aLine)&&(aLine!=("antonyms"))){

                aword.pushSynonyms(aLine, wordVector);

                }




          system("PAUSE");

          return 0;
      }
Это было полезно?

Решение

Проблема, похоже, заключается здесь:

in>>myId>>word;

В строке "синонимы" выполняется извлечение myId выходит из строя и устанавливает failbit в потоке, что также приводит к сбою следующих извлечений.Вы должны сбросить состояние контроля ошибок, прежде чем извлекать дополнительные элементы (например, слово "синонимы") из потока:

in.clear();

Другие советы

Во-первых, включите предупреждения компилятора.Это может помочь вам найти некоторые вещи, которые вы считаете нормальными, но которые на самом деле таковыми не являются.Например, функции с не-void возвращаемые типы всегда должны что-то возвращать.Если они этого не делают, то поведение вашей программы не определено, а неопределенное поведение включает в себя "работает точно так, как вы хотели, за исключением некоторых незначительных различий позже в программе". Если вы используете g ++, опция для предупреждений -Wall.

Во-вторых, обратите внимание, что не выполняется не только выделенная строка.В весь pushSynonyms функция никогда ему не звонят.Ваш класс уже описал, как использовать отладчик?Если это так, то подумайте о его использовании.Если нет, то попробуйте положить немного "cout" инструкции в вашей программе, чтобы вы могли точно видеть, как далеко продвинулась ваша программа, прежде чем что-то пойдет не так.

В-третьих, обратите внимание, что при сбое чтения потока устанавливается бит сбоя потока.Пока вы не очистите его (как показано в ответе sth), дальнейшее извлечение из этого потока происходить не может, поэтому все дальнейшие использования >> и getline потерпит неудачу.

Вы делали какую-нибудь диагностическую печать?Например, что такое synsAux.size()?Вы проверили, что находится в synline прежде чем вы начнете его обрабатывать?Вы проверили, какие числа собираются из входного потока?

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top