在使用scanf输入时,如果输入不合法,此时可以检查其返回值为0,但下次再调用时,上次不合法的输入,还在输入缓冲区中,此时就会接着不合法,如下:
#include <stdio.h>
int main(int argc,char** argv){
int id ;
int ret = scanf("%d",&id);
while(ret == 0){
ret = scanf("%d",&id);
printf("input failed\n");
}
printf("you input is %d\n",id);
return 0;
}
这样,如果输入不合法时,就会在while里不断的循环,这是因为id没有被正确的读入,此时缓冲区里的输入还在,所以下次scanf时,又会读取缓冲区中的东西。
有这么几种方法,可以解决这个问题
一,使用setbuf
功 能: 把缓冲区与流相联
用 法: void setbuf(FILE *steam, char *buf);
说明:setbuf函数具有打开和关闭缓冲机制。为了带缓冲进行I/O,参数buf必须指向一个长度为BUFSIZ(定义在stdio.h头文件中)的缓冲区。通常在此之后该流就是全缓冲的,但是如果该流与一个终端设备相关,那么某些系统也可以将其设置为行缓冲。为了关闭缓冲,可以将buf参数设置为NULL。
#include <stdio.h>
int main(int argc,char** argv){
int id ;
int ret = scanf("%d",&id);
while(ret == 0){
printf("input failed\n");
setbuf(stdin,NULL);
ret = scanf("%d",&id);
}
printf("you input is %d\n",id);
return 0;
}
#include <stdio.h>
int main(int argc,char** argv){
int id ;
int ret = scanf("%d",&id);
while(ret == 0){
printf("input failed\n");
// setbuf(stdin,NULL); 1
__fpurge(stdin);
ret = scanf("%d",&id);
}
printf("you input is %d\n",id);
return 0;
}
如果提示没有找到这个函数的话,则需要包含#include <stdio_ext.h>
三,把缓冲区全读完
#include <stdio.h>
int main(int argc,char** argv){
int id ;
char c ;
int ret = scanf("%d",&id);
while(ret == 0){
printf("input failed\n");
// setbuf(stdin,NULL); 1
// __fpurge(stdin);
//
do{
c = getchar();
}while(c != '\n' && c != EOF);
ret = scanf("%d",&id);
}
printf("you input is %d\n",id);
return 0;
}
经过测试,上面的方法都可以实现目的。