cin>>的返回值与cin.fail()的返回值是完全同步的吗?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了cin>>的返回值与cin.fail()的返回值是完全同步的吗?相关的知识,希望对你有一定的参考价值。

也可以说,用于判断的时候,用两个表达式是不是是 等效的?

是的,cin转换成 bool 类型等价于计算 !cin.fail() 的值…… 参考技术A cin >>i 返回的是流对象本身,而不是流状态,之所以能作为逻辑表达式,是因为operator bool

fail()是流对象的成员函数,若刚进行的操作失败,则返回真,否则返回假,用来判断一个流是否“坏”掉了

cin.good(),cin.fail(),cin.clear()

cin.good(),原来的值默认为1。如果输入的值与定义的变量类型不同,则输出cin.good()为0;

 1 int a;
 2 cout<<"输入一个字母:"<<endl;
 3 cin>>a; //我们用键盘输入一个char字母,而不是输入int。这时int型变量中放了char型数据,发生错误,所以failbit置1
 4 cout<<"cin.fail()="<<cin.fail()<<endl; //输出1,说明fail是true,代表出错。
 5 cout<<"输入一个数字:"<<endl; //由于failbit值为1,输入流不能正常工作
 6 cin>>a; //此时我们用键盘输入,但是此处的输入无效,因为cin.fail是true。
 7 cout<<a<<endl; //输出不确定值,因为刚才cin>>a都没有效果。所以内存a这个区域不知道是什么值。
 8 cin.clear(); //此处用cin.clear()这个函数进行流标志复位,使得cin.fail恢复正常。 
 9 cout<<"cin.fail()="<<cin.fail()<<endl; //此处failbit已为0,说明fail是false,即没有错误了。
10 cout<<"输入一个数字:"<<endl;
11 //由于上面的步骤仅仅是清除了fail错误,但刚才第一次输入的char字符并没有从流中清除,那个char类型的东西还存在在缓冲区内,所以当再次进行cin>>a时,又把那个char字符放入变量a中,类型不符导致输入流又不能正常工作,cin.fail再次崩溃为true。
12 cin>>a;
13 cout<<a<<endl; //还是没有输入成功,因此输出a的话还是输出不确定值
14 cout<<"cin.fail()="<<cin.fail()<<endl; //由于刚才缓冲区的错误,所以在此处failbit又为1true
15 cin.clear(); //用clear方法再次修复输入流
16 cin.ignore(); //这次我们用ignore方法取走刚才流中的字符,也就是让缓冲区的那个char字符清除。
17 cout<<"输入一个数字:"<<endl; //再次接收输入,这次输入int型的数字,类型和变量符合,所以正常输出了
18 cin>>a;
19 cout<<"a="<<a<<endl;
20 //现在再看一下输入流的failbit
21 cout<<"cin.fail()="<<cin.fail()<<endl;//输出0,表明输入流已恢复正常

代码引用自 yinlung 的CSDN 博客 

以上是关于cin>>的返回值与cin.fail()的返回值是完全同步的吗?的主要内容,如果未能解决你的问题,请参考以下文章

C++ 中的 cin.fail() 和 !cin 有啥区别?

使用 cin::fail() 从标准输入进行无限循环读取

关于cin.sync()的解释

错误处理

使用时如何重置std::cin?

输入数字和字母时 cin.fail 不起作用