(转自:https://blog.csdn.net/lv_xinmy/article/details/22393337)
在使用scanf输入时,如果输入不合法,此时可以检查其返回值为0,但下次再调用时,上次不合法的输入,还在输入缓冲区中,此时就会接着不合法,如下:
[html] view plain copy
- #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。
[html] view plain copy
- #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;
- }
二,使用__fpurge
[html] view plain copy
- #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>
三,把缓冲区全读完
[html] view plain copy
- #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;
- }
经过测试,上面的方法都可以实现目的。