i was wrong!
虽然setbuf可以让程序自己管理缓冲,但是像getchar,gets这些标准IO函数还是要通过隐藏的stdin进行操作,而stdin是啥呢?还是一个FILE*,而FILE*自己内部有很多东西比如记录下一个字符的位置,有没有读尽缓存,因此直接通过memset去清除缓存还是很野蛮的动作,比较危险,但是文章也还有点价值,我实在是不舍得删,就先写一段放在这里吧
#include <stdio.h>
#include <stdlib.h> int main(int argc, char *argv[])
{
char buffer[] = {}; gets(buffer);
printf("%s\n",buffer);
system("PAUSE");
return ;
}
一般来说,我们从命令行输入文本之后按回车,输入被输入进程序的输入缓存,gets可以读出来,但是如果我们想输入多行,让gets分几次读出,就需要手工输入一个换行符,在输入里写入\n是不可以的,在windows下可以从键盘输入:按住alt, 输入小键盘上的数字 10 经试验,是可以的
我一个朋友的特殊需求,要求一旦通过gets读取输入后,下次就要求用户重新输入
#include <stdio.h>
#include <stdlib.h> int main(int argc, char *argv[])
{
char buffer[] = {};
char stdin_buffer[] = {}; setbuf(stdin,stdin_buffer); //程序自己管理stdin内存
gets(buffer);
printf("%s\n",buffer); memset(stdin_buffer,,); //手工清内存 gets(buffer);
printf("%s\n",buffer); //读取一行输入 gets(buffer);
printf("%s\n",buffer); // 读取第二行输入,如果输入两行的情况下,不需要提示用户再次输入
// 但是如果程序手工清理了缓存,程序会要求用户输入 system("PAUSE");
return ;
}
貌似上面的程序看起来很没品,我重写了一个版本:
#include <stdio.h>
#include <stdlib.h> int main(int argc, char *argv[])
{
char buffer[] = {};
char stdin_buffer[] = {}; setbuf(stdin,stdin_buffer); //程序自己管理stdin内存 for(;;)
{
gets(buffer);
if(strcmp(buffer,"q")==)
{
break; // 输入q退出循环
}
else
{
//从用户的输入里读且只读一行。然后清空缓存,让用户重新输入
printf("type: %s\n",buffer);
memset(stdin_buffer,,);
}
} system("PAUSE");
return ;
}