c语言解决从scanf()函数和getchar()函数从输入缓冲区得到\n的问题

scanf()函数和getchar()函数是从输入缓冲区得到字符数据的,所以会出现下次接受字符为\n的情况,这种情况可以用一下两个方法:

方法1:C语言里提供了函数清空缓冲区,只要在读数据之前先清空缓冲区就没问题。

这个函数是fflush(stdin)。

方法2:自己取出缓冲区里的残留数据。比如:

char ch1, ch2;

ch1 = getchar();//这个字符是我们想要的

ch2 = getchar(); //这个字符是\n

方法3:使用库函数

#include <termios.h>
#include <stdio.h>
#include <unistd.h>
#include <string.h>
int main()
{
char ch; //存取从键盘上读取到的数
struct termios old_term;
struct termios cur_term;
int ret ;
tcgetattr(STDIN_FILENO, &old_term);
memcpy(&cur_term, &old_term, sizeof(cur_term));
cur_term.c_lflag &= ~(ICANON);
cur_term.c_cc[VMIN] = 1;
cur_term.c_cc[VTIME] = 0;
ret = tcsetattr(STDIN_FILENO, TCSANOW, &cur_term);
if (ret < 0)
{
      printf("Can't set\n");
      return 1;
}
printf("Are you OK? [Y/n] ");
fflush(stdout);

ret = read(STDIN_FILENO, &ch, 1);
if (ret <= 0)
{
       printf("Error\n");
}
else
{
if (ch == 'y' || ch == 'Y')
{
      printf("\nYour choice is YES\n");
}
else if (ch == '\n')
{
      printf("You make no choice, default to YES\n");
}
else if (ch == 'n' || ch == 'N')
{
      printf("\nYour choice is NO\n");
}
else
{
      printf("\nInvalid choice\n");
}
}
tcsetattr(STDIN_FILENO, TCSANOW, &old_term);
return 0;

}

扫描二维码关注公众号,回复: 2889896 查看本文章

猜你喜欢

转载自blog.csdn.net/weixin_39465823/article/details/81873149