问题描述:
利用cin获取输入时,输入类型错误可能会导致出现异常情况
解决方案:
1.cin后,判断输入是否出错 a.直接使用cin.fail(),有错就返回True b.我在网上看见有人用cin.rdstate()来判断是否出错,于是就上cplusplus查了一下这个函数的作用 cin.rdstate()的返回值是std::ios_base::iostate std::ios_base::iostate有四种值:goodbit(the value zero),eofbit,failbit,badbit,如果输入没问题的话就是goodbit,也就是会返回0; 2.判断完是否出错后,就要清除错误 也是在网上看到了两种方法 a.使用cin.sync()(清除缓冲区中未读的信息)和cin.clear()(清除错误标志位), 按道理来说这两个一清除应该就没问题,但是就是不行(不知道是不是环境的原因); 后面查了一下,说cin.sync()根本就不是清除缓冲区,而且同步缓冲区,查了好久,也没查出个所以然,就放弃这个函数了; b.使用cin.ignore() cin.ignore()函数是C++标准输入流(cin)中的一个方法。cin.ignore()函数中有两个参数, 分别为数值型的a 和 字符型的 ch ,即cin.ignore( a, ch )。它表示从输入流 cin 中提取字符, 提取的字符被忽略,不被使用。而每抛弃一个字符,它都要进行计数和比较字符:如果计数值达到 a 或者被抛弃的字符是 ch , 则cin.ignore() 函数执行终止; 如果默认不给参数的话,默认参数为cin.ignore(1, EOF),即把EOF前的1个字符清掉,没有遇到EOF就清掉一个字符然后结束。 得出只要第一个参数足够大,就能一次把缓冲区内的所有数据清除掉,所以就这样使用cin.ignore(numeric_limits::max(), ‘\n’); 所以得出结论,判断cin出错后,先cin.clear()清除错误标志位,然后cin.ignore()清除缓冲区内的数据;
int input_num = 0;
cin >> input_num;
ios_base::iostate flag = cin.rdstate();
cout << flag<<endl;
while(cin.fail())
{
cerr << "输入错误!请重新输入:";
cin.clear();
cin.ignore(numeric_limits<streamsize>::max(), '\n');
cin >> input_num;
}
|