cin>>的返回值与cin.fail()的返回值是完全同步的吗?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了cin>>的返回值与cin.fail()的返回值是完全同步的吗?相关的知识,希望对你有一定的参考价值。
也可以说,用于判断的时候,用两个表达式是不是是 等效的?
是的,cin转换成 bool 类型等价于计算 !cin.fail() 的值…… 参考技术A cin >>i 返回的是流对象本身,而不是流状态,之所以能作为逻辑表达式,是因为operator boolfail()是流对象的成员函数,若刚进行的操作失败,则返回真,否则返回假,用来判断一个流是否“坏”掉了
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()的返回值是完全同步的吗?的主要内容,如果未能解决你的问题,请参考以下文章