在使用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; }
经过测试,上面的方法都可以实现目的。