getchar()函数是获取一个字符。说到这里就有人问了,为什么他的返回类型是int?
因为实际上EOF=end of file(-1),EOF实际上就等于-1。当你返回失败的时候返回的是-1,所以说要用int,用char肯定不行。而且在底层逻辑上,所有的字符在ASC||值上都对应着一个整型数值。
#define _CRT_SECURE_NO_WARNINGS 1
#include
int main()
{
int ch = 0;
while ((ch = getchar()) != EOF)
{
printf("%c\n", ch);
putchar(ch);//这里的putchar()就是在控制面板上打印一个字符!
}
return 0;
}
代码运行如下图:
当我在键盘上输入一个q的时候,printf()打印一个q,putchar()打印一个q。
最后要我想程序结束的话,按上一个CTRL加z,再按下回车即可。
我们再来看看下面这段代码
#include
int main()
{
char passward[20] = { 0 };
printf("请输入密码:>");
scanf("%s",passward);//123456
char input = 0;
printf("请确认密码:>(Y/N)");
input = getchar();
if (input == 'Y')
{
printf("确认成功!\n");
}
else
{
printf("确认失败!\n");
}
return 0;
}
密码是当然可以正常输入,但是在确认密码的那一步太着急了,我们没有确认,他就直接:“确认失败”了!?
这里的问题是为什么呢?接下来就有必要跟大家引出这个:输入缓冲区 的概念。
我们都知道scanf()和getchar()都是需要你在键盘上输入的函数,但是我们键盘上打印什么,他就直接输入到里面了吗?实际上在键盘和scanf与getchar这类函数之间,有一个输入缓冲区域的东西。
当你在输入123456之后,又在键盘上按了一个回车,也就是\n。然后scanf只取走123456存放到password中。此时在输入缓冲区中还存在一个字符,\n。当下一步你要确认密码是否输入正确的时候,那么getchar()就来到输入缓冲区里面来,看看里面还有什么东西,当你没输入的时候,它里面已经存在了一个\n,所以说直接确定失败,因为那不是Y。
那么问题来了,如何避免这种情况的发生呢?我们可以在确定之前添加一个getchar(),把这个斜杠n直接吃掉。
#include
int main()
{
char passward[20] = { 0 };
printf("请输入密码:>");
scanf("%s",passward);//123456
getchar();//负责吃掉你,当时按下的回车键也是字符:\n。
char input = 0;
printf("请确认密码:>(Y/N)\n");
input = getchar();
if (input == 'Y')
{
printf("确认成功!\n");
}
else
{
printf("确认失败!\n");
}
return 0;
}
那么此时此刻代码就可以正常的运行了。
但是还有一件事,我们需要对这个密码进行升级,那么这种方法又不可行。
比如说我现在设置的密码为:123456 abc(中间有个空格)
运行一下:
此时还是出现了我们刚才出现的问题。这次password只存放了123456,也就是空格之前的所有东西。
那么这个问题如何解决呢?当然聪明的你也想到了,用一个循环的getchar()来实现
所以我们需要把缓冲区中的东西先全部清走。
那我们就用一个循环,只要没读到\n,我们就一直用getchar读。
即
while (getchar() != '\n')
{
;
}
此循环就是用来清空输入缓冲区,从而避免你在确认密码时输入Y或N会出现差错的问题。
整段代码如下图
#include
int main()
{
char passward[20] = { 0 };
printf("请输入密码:>");
scanf("%s",passward);//123456 abc
//getchar();//负责吃掉你,当时按下的回车键也是字符:\n。
while (getchar() != '\n')
{
;
}//此循环用来清空输入缓冲区,直到遇到\n结束为止。
//只有清空输入缓冲区的时候,你才能进行下一步的确认密码时,输入缓冲区空空如也,不会出现差错。
char input = 0;
printf("请确认密码:>(Y/N)\n");
input = getchar();
if (input == 'Y')
{
printf("确认成功!\n");
}
else
{
printf("确认失败!\n");
}
return 0;
}
运行一下子:
加了while循环后,getchar便可获取缓冲区中多余的字符,避免他们干扰后面的getchar的判断。
这里有一个巧妙的地方,由于循环的判断次数总比循环次数多一次,使得getchar在最后也能将'\n'获取除掉。
getchar()读取的原理是:先读取(拿走),再判断!!!针对于这个while循环。所以说最终必定会将斜杠n拿走,因为是:先读取(拿走),再判断!!!
总结
getchar与scanf不是直接从键盘上获取数据,而是通过输入缓冲区来获取。
以上就是关于getchar的用法的实例解析。如果对你有帮助,记得点赞+关注哦!
我的主页还有其他文章,欢迎学习指点。关注我,让我们一起学习,一起成长吧!