int getchar ( void )
这个是getchar函数的原型,功能就是从屏幕上获取一个字符。
关于他的返回值,如果获取成功,就返回获取到的字符的ASCII码值,如果获取失败,就返回EOF,也就是-1。这也就能解释当初设计这个函数时为什么要把返回值设计成int,而不直接返回字符char,因为ASCII码值的范围是0~127,没有-1。
#include
int main()
{
int ch = 0;
while ((ch = getchar()) != EOF)
putchar(ch);
return 0;
}
while循环和getchar函数搭配使用可以实现字符串输入输出,而这样的代码稍做修改就可以用于清理缓冲区。
首先我们要了解什么是缓冲区,为什么我们要清理缓冲区。下面我们通过一个例子来了解一下。
现在我要求编写一段代码,模拟用户设置密码,先让用户输入要设置的密码,再询问他是否确定设置。
我给出这样一段代码
#include
int main()
{
char arr[20] = { 0 };
printf("请输入密码>:");
scanf("%s", arr);
printf("请确认密码(Y/N)>:");
char ch = getchar();
if ('Y' == ch)
{
printf("设置成功\n");
}
else
{
printf("设置失败\n");
}
return 0;
}
运行结果如下
和我预期的不一样,当我输入完密码后程序直接跑完了,根本没有让我确认密码,为什么会出现这种情况?原因如下:
像getchar,scanf这些函数读取字符不是直接从键盘上接收数据的,而是先把数据加载到缓冲区,再从缓冲区中拿数据。
程序开始运行,轮到scanf读取数据时,看见缓冲区内没有数据,于是程序停了下来,等待我从键盘上输入数据。
我输入”1234“,再按下回车键,此时缓冲区中就有”1234\n”这5个字符,scanf函数于是就把“1234”读走了,剩下‘\n’还留在缓冲区内。
所以当gerchar读取字符时,看见缓冲区内有数据,直接就把‘\n’读走了,根本不会停下, 然后‘\n’ != Y,密码设置失败。
要想解决这个问题,就必须再scanf函数读取数据后清理缓冲区
#include
int main()
{
char arr[20] = { 0 };
printf("请输入密码>:");
scanf("%s", arr);
printf("请确认密码(Y/N)>:");
getchar(); //用来读取‘\n’
char ch = getchar();
if ('Y' == ch)
{
printf("设置成功\n");
}
else
{
printf("设置失败\n");
}
return 0;
}
总结来说就一句话:
按下回车键后才能触发scanf和getchar函数读取字符,但是在回车换行的同时也将‘\n’放到了缓冲区,scanf函数不会读取\n,而getchar函数会读取\n,故可用getchar函数刷新缓冲区
但是这样真的就没问题了吗?
我输入时加上了空格,程序依然一口气跑完,显示输入失败。
这是因为我输入数据之后,缓冲区存的是“1234 abc\n”。scanf读取数据,遇到空格后就停止了。此时剩下的数据为“ abc\n”5个字符,getchar()再把空格读走,最后ch被赋值为‘a’,所以设置失败。
由此可见,有时候缓冲区不止剩下‘\n’,还有其他的一些字符,所以getchar应该一直读取,直到把‘\n’干掉才停下。
int main()
{
char arr[20] = { 0 };
printf("请输入密码>:");
scanf("%s", arr);
while (getchar() != '\n')
{
;
}
printf("请确认密码(y/n)>:");
char ch = getchar();
if ('y' == ch)
{
printf("确认成功\n");
}
else
{
printf("确认失败\n");
}
return 0;
}
今天分享到此结束,欢迎留下你的宝贵评论