问题描述:
利用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;
//if (cin.rdstate()) || if (cin.rdstate() != ios::goodbit) 这两个也判断cin是否出错
ios_base::iostate flag = cin.rdstate();
cout << flag<<endl;
while(cin.fail())
{
cerr << "输入错误!请重新输入:";
cin.clear();
//cin.ignore();
//cin.sync();
//cin.ignore(1, EOF);
cin.ignore(numeric_limits<streamsize>::max(), '\n');
cin >> input_num;
}
本文介绍了在C++中处理cin输入错误的方法,包括通过cin.fail()和cin.rdstate()检查错误状态,以及使用cin.clear()和cin.ignore()清除错误和缓冲区数据,确保程序能正确运行。
635

被折叠的 条评论
为什么被折叠?



