当前位置: 首页 > news >正文

C语言输入输出缓冲机制

文章目录

  • 输入输出缓冲机制
    • 概述
    • 为什么要有缓冲区
      • 缓冲区的类型
      • 引发缓冲区的刷新
    • 原理实现

输入输出缓冲机制

概述

  缓冲区又称为缓存,它是内存空间的一部分。也就是说,在内存空间中预留了一定的存储空间,这些存储空间用来缓冲输入 或者输出的数据,这部分预留的空间叫做缓冲区。缓冲区根据其对应的是输入设备还是输出设备,分为输入缓冲区和输出缓冲区。

为什么要有缓冲区

  1. 减少IO设备的操作
  2. 提高计算机的运行速度。

 比如:我们从磁盘里读取信息,先把读出的数据放在缓冲区,计算机再直接从缓冲区中取数据,等缓冲区的数据取完后再去磁盘中读取,这样就减少磁盘的读写次数,再加上计算机对缓冲区的操作大大快于磁盘的操作,故应用缓冲区可大大提高计算机的运行速度

缓冲区的类型

  • 全缓冲:当填满缓冲区之后,才会进行实际IO操作。 比如 对磁盘文件的读写。 —window 全缓冲大小4096字节 linux 全缓冲大小 1024字节
  • 行缓冲:当在输入和输出中遇到换行符时,执行真正的IO操作,也就是冲刷缓冲区的数据。比如键盘输入数据
  • 不带缓冲:也就是不进行缓冲,标准出错情况stderr是典型代表,这使得出错信息可以直接尽快地显示出来。

引发缓冲区的刷新

  1. 遇到换行符\n
  2. 缓冲区满(溢出)
  3. 执行fflush(stdout),手动刷新缓冲区

原理实现

请添加图片描述

说明:

  • 录入:输入输出操作的内部采用的缓冲机制,也就是当我们用scanf()输入数据时,并不是直接将键盘录入的数据存储到内存变量中,而是系统会先去输入缓冲区查看是否有符合类型的数据,如果存在将直接输入缓冲区中的数据到内存变量,此时就不用键盘录入,否则猜需要键盘录入复合类型的数据。
  • 输出:相同道理,当我们使用printf()输出数据时,也并不是直接将内存变量存储的数据输出到输出设备,而是先存储到输出缓冲区,当输出缓冲区被充满,或输出缓冲区中出现换行符,或者执行fflush(),才会将输出缓冲区的数据输出到标准输出设备。(打印机也是,我们测试用的是控制台显示终端)
http://www.lryc.cn/news/406807.html

相关文章:

  • javaEE-03-cookie与session
  • EtherNet/IP转Profinet协议网关(经典配置案例)
  • 华为云依赖引入错误
  • 【Ubuntu】Ubuntu 配置镜像源(ARM)
  • 速腾聚创激光雷达复现FAST-LIO
  • k8s核心知识总结
  • 语言模型及数据集
  • linux如何卸载python3.5
  • 【BUG】已解决:TypeError: expected string or bytes-like object
  • 在linux上面用drissionpage自动化遇到反爬?
  • vue3大事件管理系统 === 首页 layout 文章分类页面 -
  • 堆的基本实现
  • Ubuntu上编译多个版本的frida
  • 概率论三大分布
  • Spring系统学习-基于XML的声明式事务
  • iOS中的MVVM设计模式
  • ES中的数据类型学习之ARRAY
  • vue网络请求
  • 几何光学基本原理——费马原理和射线方程
  • OpenCV车牌识别技术详解
  • 解决llama_index中使用Ollama出现timed out 问题
  • Python爬虫技术 第14节 HTML结构解析
  • 【vue3|第18期】Vue-Router路由的三种传参方式
  • ElasticSearch(六)— 全文检索
  • Oracle核心进程详解并kill验证
  • 【BUG】已解决:SyntaxError:positional argument follows keyword argument
  • 怎样在 Nginx 中配置基于请求客户端 Wi-Fi 连接状态的访问控制?
  • 逆向案例二十九——某品威客登录,请求头参数加密,简单webpack
  • 河道高效治理新策略:视频AI智能监控如何助力河污防治
  • [React]如何提高大数据量场景下的Table性能?