【转帖】cin输入流的fail(),clear(),sync(),例子详解___有疑惑的看过来
by 健 张 - 星期六, 31 十月 2009, 05:26 下午
 

考虑如下代码:
#include <iostream>
using namespace std;
int main()
{
int a;
while(cout<<"input a integer (1-10) :",cin>>a,! (a>=1 && a<=10))
cout<<"try again!"<<endl;
return 0;
}

本意是让用户选择一个1-10的数,如果不是1-10的数则重新输入。

分析:
如果用户输入了一个不在1-10的 int,那么,程序会正确的执行,并且提示用户重新输入。
但是如果用户错误的输入了一个字符char,那么,后果就是一直执行while循环!

错误分析:
当cin尝试将输入的字符读为int型数据失败后,会产生一个错误状态--cin.fail().而要用cin读取输入流中的数据,输入流必须处于无错误状态。因此,由于错误状态的存在,会一直执行while循环。

错误修正:
#include <iostream>
using namespace std;
int main()
{
int a;
while(cout<<"input a integer (1-10) :",cin>>a,! (a>=1 && a<=10) || cin.fail())
{
cout<<"try again!"<<endl;
cin.clear(); //清除std::cin的错误状态
cin.sync(); //清空输入缓冲区
}
return 0;
}

加上判断输入是否成功的cin.fail()以及修正错误输入的cin.clear()和cin.sync();

其中std::cin.sync();这一句必不可少,因为所有从标准输入设备输入的数据都是先保存在缓冲区中,然后istream对象再从缓冲区中进行提取。如果不清空缓存,下次在读取数据的时候又会再次产生错误,也会陷入死循环。

想要判断输入是否失败,不要用 if (!cin>>K),要用 if( cin>>K , cin.fail()) 。前者可能会失败。

-----------------------------------------------------------------

后记:良好的编程习惯,确保程序的健壮性

原文出处:http://hi.baidu.com/luosiyong/blog/item/384f9d8b0280b8799e2fb4c8.html
posted on 2013-03-31 17:35  侠骨豪情  阅读(308)  评论(0编辑  收藏  举报