c/c++输入流刷新,解决不合法输入导致的死循环问题

首先给出代码,这段代码的原意是,从键盘输入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)时,会先看到输入流错误标记,直接判断条件成立,于是输出那段信息,然后又进入循环。因此,需要做两件事情。

  1. 清除输入流的错误标记
  2. 将输入流中的非法字符中清除
    这两步缺一不可。于是代码改成这样就可以了。
#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;
	
}

猜你喜欢

转载自blog.csdn.net/Fei20140908/article/details/104880757