首先给出代码,这段代码的原意是,从键盘输入a,然后判断a是否读取成功,如果没有就打印信息,并且再次让用户输入,直到用户输入一个合法输入才停止。
c++代码
#include <iostream>
using namespace std;
int main() {
int a=0;
while (1) {
if (!(cin >> a))
{
cout << "I'm in the loop!\n";
}
else
break;
}
cout << a << endl;
return 0;
}
然而,上面的代码运行时,如果在键盘种输入一个字符而不是数字,就会进入死循环,而不是打印信息后再次接收用户的键盘输入。
对于这个现象的解释,是不合法输入导致输入流有状态错误标记,并且输入的不合法字符一直留在输入流。当判断!(cin>>a)
时,会先看到输入流错误标记,直接判断条件成立,于是输出那段信息,然后又进入循环。因此,需要做两件事情。
- 清除输入流的错误标记
- 将输入流中的非法字符中清除
这两步缺一不可。于是代码改成这样就可以了。
#include <iostream>
using namespace std;
int main() {
int a=0;
while (1) {
if (!(cin >> a))
{
cout << "I'm in the loop!\n";
cin.clear(); // 清除输入流错误标记
cin.ignore(1024,'\n');// 取走刚才输入流中的字符
// cin.ignore()默认取走一个字符
}
else
break;
}
cout << a << endl;
return 0;
}
c代码
#include <cstdio>
int main() {
int a = 0;
while (1) {
if (!scanf("%d",&a))
{
printf("I'm in the loop!\n");
}
else
break;
}
printf("%d\n",a);
return 0;
}
上面这个代码等价于那段c++的代码,
解决方案:
#include <cstdio>
int main() {
int a = 0;
while (1) {
if (!scanf("%d",&a))
{
printf("I'm in the loop!\n");
rewind(stdin);
}
else
break;
}
printf("%d\n",a);
return 0;
}