有关cin.fail,cin.clear,cin.sync的应用

转自:http://blog.gishome.org/post-73.html

/*有关cin.fail(),cin.clear(),cin.sync()的应用*/

 这个例子可以让我们了解c++中输入操作符cin的一些缓冲问题

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

/************************************************************************************/

你可能感兴趣的:(有关cin.fail,cin.clear,cin.sync的应用)