C语言中为什么要引入缓冲区

发布时间:2021-08-30 11:35:14 作者:小新
来源:亿速云 阅读:251

这篇文章主要为大家展示了“C语言中为什么要引入缓冲区”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“C语言中为什么要引入缓冲区”这篇文章吧。

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

缓冲区根据其对应的是输入设备还是输出设备,分为输入缓冲区和输出缓冲区。

为什么要引入缓冲区

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

又比如,我们使用打印机打印文档,由于打印机的打印速度相对较慢,我们先把文档输出到打印机相应的缓冲区,打印机再自行逐步打印,这时我们的CPU可以处理别的事情。

现在您基本明白了吧,缓冲区就是一块内存区,它用在输入输出设备和CPU之间,用来缓存数据。它使得低速的输入输出设备和高速的CPU能够协调工作,避免低速的输入输出设备占用CPU,解放出CPU,使其能够高效率工作。

缓冲区的类型

缓冲区 分为三种类型:全缓冲、行缓冲和不带缓冲。

1) 全缓冲

在这种情况下,当填满标准I/O缓存后才进行实际I/O操作。全缓冲的典型代表是对磁盘文件的读写。

2) 行缓冲

在这种情况下,当在输入和输出中遇到换行符时,执行真正的I/O操作。这时,我们输入的字符先存放在缓冲区,等按下回车键换行时才进行实际的I/O操作。典型代表是标准输入(stdin)和标准输出(stdout)。

3) 不带缓冲

也就是不进行缓冲,标准出错情况stderr是典型代表,这使得出错信息可以直接尽快地显示出来。

下面开始本文的正文:通过实例讲解C语言中的printf()缓冲问题

起步

C语言中为什么要引入缓冲区

标准输出被滞后了. 不同编译器出来的结果可能不一样. 我在windows平台的 VC++6.0 上是121212.

分析

标准输出和标准出错的缓冲机制不同,标准出错不缓冲,标准输出有缓冲.

什么情况下会刷新缓冲区?

附录

示例代码:

#include <stdio.h>

int main(int argc, char const *argv[])
{
 int i;
 for (i = 0; i < 3; ++i)
 {
 printf("1");
 fprintf(stderr, "2");
 }
}

找到了让 windows 平台也使用输出缓冲的方式了:

#include <stdio.h>
char buf[512]; 
int main(int argc, char const *argv[])
{
 setvbuf(stdout, buf, _IOLBF, 512);
 int i;
 for (i = 0; i < 3; ++i)
 {
 printf("1");
 fprintf(stderr, "2");
 }
}

以上是“C语言中为什么要引入缓冲区”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

推荐阅读:
  1. web项目要引入redis的原因
  2. php要c语言的支持吗

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

c语言

上一篇:MySQL几种常用的存储引擎的区别

下一篇:Java中的动态代理是什么

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》