考虑如下代码:
#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