失败后的istream阅读

时间:2016-05-11 01:28:17

标签: c++ istream

我有一小段代码来读取用户数据,如下所示:

#include<iostream>
#include<vector>
#include<algorithm>
#include<ios>
#include<iomanip>
#include<string>

using namespace std;

istream& read_dt(istream& in, vector<int>& nmbr) {
if(in) {
 nmbr.clear();

 int x;
  while(in >> x) {
   nmbr.push_back(x);
  }
  if(in.fail()) {
   string s;
   in >> s;
   in.clear();
  }
 }
 return in;
}

int main() {
 vector<int> data;
 cout << "Enter all the data: " << endl;
 read_dt(cin, data);
 cout << "Size: " << data.size() << endl;
}

当我使用以下数据编译并执行上述程序时:     1 2 3 4 r t 5 6 7

我似乎得到了一个大小为4而不是大小为7的向量。我在上面实现的是,当用户将无效输入作为数据(在本例中为'r'和't')时,该数据被丢弃并清除输入(使用in.clear()),其余输入被“推”到矢量数据中。

但这似乎并没有发生。我究竟做错了什么?有人可以帮忙吗?

感谢。

1 个答案:

答案 0 :(得分:5)

在流上发生故障后,流将保持故障状态(读取可以成功),直到您清除()流。

现在,您在清除之前尝试从流中读取错误数据,以便读取永远不会成功。此外,在您清除了错误数据后,您没有提供任何方法继续从流中读取数据 - 您执行while循环,然后当它退出时,您清除错误数据(如果有的话) )从流中,然后返回你读的内容。

对于这样的情况,你几乎需要与流上的eof()分开测试,并继续阅读,直到你到达eof() - 数据被转换,否则它就会被转换。被忽略了。

鉴于您在下一个空白区域之前尝试忽略错误数据,我会使用ignore而不是将数据读入字符串。在阅读你不关心的数据时,没有真正的意义。

#include<iostream>
#include<vector>
#include<algorithm>
#include<ios>
#include<iomanip>

using namespace std;

istream& read_dt(istream& in, vector<int>& nmbr) {
    if (in) {
        nmbr.clear();

        int x;
        for(;;) { 
            in >> x;

            if (in.eof())
                break;

            if (in.fail()) {
                in.clear();
                in.ignore(100, ' ');
            }
            else
                nmbr.push_back(x);
        } 
        return in;
    }
}

int main() {
    vector<int> data;
    cout << "Enter all the data: " << endl;
    read_dt(cin, data);
    cout << "Size: " << data.size() << endl;
}