scanf和getchar大家都用过吧!那么缓存区的概念你必须了解!(下)

简介: scanf和getchar大家都用过吧!那么缓存区的概念你必须了解!(下)

💬键盘缓冲区

  • 给大家提一个问题难道想scanf和getchar这样的
  • 接收函数难道是直接从键盘上接收函数吗?

⛳️说明:

👑 其实他们之间还有一个函数缓冲区的概念。

  • scanfgetchar函数和键盘之间有一个键盘缓冲区
  • 键盘输入之后把数据放到缓冲区然后再进行读取

scanf 演示

  • 📜说明:当我们缓存区如上图时什么都没有scanf( )函数就会等待
📖 运行错误的原因
  • 📌 而当我们输入123456然后换 缓存区中存的是123456加上\n这回车换行符
  • 🌱 这时我们的scanf就会把缓冲区中的123456给存到数组中去。
  • 🌱 但是\n这个字符还是留了下来没被清理掉。

    所以我们的getchar函数看到里面有内容。
    就不进行等待直接读取了。
    搜嘎这时我们程序出现错误的原因就找到了。

原因找到,就好解决了,既然是换行符\n被清理了导致的。

那么我们就把\n提前清理就好了。

🎬 原因找到,实战开始!

📚 解决方法

📑 方法一:

  • 🌱 最简单的方法,我们单独放上一个getchar()把换行符\n提前读取了就好了
#include <stdio.h>
int main()
{
  //123456
  char password[20] = {0};
  printf("请输入密码:>");
  scanf("%s", password);//123456 abc
  printf("请确认密码(Y/N):");
  char input = 0;
  getchar();//\n
  if ('Y' == input)
    printf("确认成功\n");
  else
    printf("确认失败\n");
  return 0;
}

  • 📌但是这种代码只适合这一种场景,不全面没有完全解决问题。
  • 📌用我们的古话来说就是治标不治本。
  • 📌当我们换个场景输入 123456 abc 的时候又错误了

  • 我们来一起好好分析一下?

  • ⛳️而getchar只能清理一个字符所以会出现下面这种情况

  • 我们的getchar直接就把b读取给input变量了导致if判断为读取失败。

📑 方法二:

  • 🌱前面说了错误原因getchar( )只读取了一个字符,那么用循环清理掉多个字符不就好了。
  • 🌱让getchar() 只要没有读取错误就一直循环!就完美解决错误啦!
#include <stdio.h>
int main()
{
  //123456
  char password[20] = {0};
  printf("请输入密码:>");
  scanf("%s", password);//123456 abc
  printf("请确认密码(Y/N):");
  char input = 0;
  //清理掉缓冲区中剩余的数据
  while (getchar() != '\n')
  {
    ;
  }
  input = getchar();
  if ('Y' == input)
    printf("确认成功\n");
  else
    printf("确认失败\n");
  return 0;
}

循环解决缓冲区

总结

✅ 归纳:

好了以上就是关于getchar()函数的用法,和关于缓冲区的概念就讲完了!

  getchar的参数

  getchar的返回值

  EOF的讲解

  缓冲区概念的讲解

☁️ 学会这些大家就不会再为,scanf函数和getchar函数使用时找不到错误而发愁了!

看到这里了还不给博主扣个⛳️ 点赞☀️收藏 ⭐️ 关注

💛 💙 💜 ❤️ 💚💓 💗 💕 💞 💘 💖

拜托拜托这个真的很重要!

你们的点赞就是博主更新最大的动力!

有问题可以评论或者私信呢秒回哦。

目录
相关文章
|
存储 缓存 算法
Edge Cache(边缘缓存) 的概念
Edge Cache(边缘缓存) 的概念
|
10月前
|
存储 缓存 vr&ar
scanf和getchar大家都用过吧!那么缓存区的概念你必须了解!(上)
scanf和getchar大家都用过吧!那么缓存区的概念你必须了解!
55 0
|
存储 缓存 NoSQL
Redis缓存穿透和雪崩相关概念(面试高频,工作常用)
Redis缓存的使用,极大的提升了应用程序的性能和效率,特别是数据查询方面,但同时,它也带来了一些问题,其中,最重要的问题,就是数据的一致性问题。从严格意义上讲,这个无解。如果对数据的一致性要求很高,那么就不能使用缓存。
134 0
Redis缓存穿透和雪崩相关概念(面试高频,工作常用)
|
缓存 NoSQL 算法
Redis缓存数据库应用概念以及Redis基本操作(一)
redis基本概念及部署redis 1.redis介绍 rediis是一种基于键值对的NoSQL数据库,与很多键值对数据库不同,redis中的值可以有string、hash、list、set、zset、geo等多种数据结构和算法组成。
295 0
Redis缓存数据库应用概念以及Redis基本操作(一)
|
缓存 NoSQL Redis
Redis中缓存雪崩、缓存穿透、缓存降级等概念的简单说明
Redis中缓存雪崩、缓存穿透、缓存降级等概念的简单说明(言简意赅,不啰嗦): 1、缓存雪崩:缓存集中过期,新缓存还没能刷入进来,导致所有请求(查询)都走数据库,给数据库内存和CPU巨大压力,严重导致数据库宕机,进而造成系统崩溃。
2095 0
|
2天前
|
缓存 NoSQL 中间件
【后端面经】【缓存】36|Redis 单线程:为什么 Redis 用单线程而 Memcached 用多线程?epoll、poll和select + Reactor模式
【5月更文挑战第19天】`epoll`、`poll`和`select`是Linux下多路复用IO的三种方式。`select`需要主动调用检查文件描述符,而`epoll`能实现回调,即使不调用`epoll_wait`也能处理就绪事件。`poll`与`select`类似,但支持更多文件描述符。面试时,重点讲解`epoll`的高效性和`Reactor`模式,该模式包括一个分发器和多个处理器,用于处理连接和读写事件。Redis采用单线程模型结合`epoll`的Reactor模式,确保高性能。在Redis 6.0后引入多线程,但基本原理保持不变。
21 2
|
3天前
|
缓存 NoSQL Redis
【后端面经】【缓存】36|Redis 单线程:为什么 Redis 用单线程而 Memcached 用多线程?--epoll调用和中断
【5月更文挑战第18天】`epoll`包含红黑树和就绪列表,用于高效管理文件描述符。关键系统调用有3个:`epoll_create()`创建epoll结构,`epoll_ctl()`添加/删除/修改文件描述符,`epoll_wait()`获取就绪文件描述符。`epoll_wait()`可设置超时时间(-1阻塞,0立即返回,正数等待指定时间)。当文件描述符满足条件(如数据到达)时,通过中断机制(如网卡或时钟中断)更新就绪列表,唤醒等待的进程。
32 6