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

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

成都创新互联公司专业提供成都服务器托管服务,为用户提供五星数据中心、电信、双线接入解决方案,用户可自行在线购买成都服务器托管服务,并享受7*24小时金牌售后服务。

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

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

为什么要引入缓冲区

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

又比如,我们使用打印机打印文档,由于打印机的打印速度相对较慢,我们先把文档输出到打印机相应的缓冲区,打印机再自行逐步打印,这时我们的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.

分析

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

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

  • 程序结束时调用 exit(0) .

  • 遇到 \n , \r 时会刷新缓冲区.

  • 手动刷新 fflush .

  • 缓冲区满时自动刷新.

附录

示例代码:

#include 

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

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

#include 
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语言中为什么要引入缓冲区”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!


名称栏目:C语言中为什么要引入缓冲区
本文URL:http://csdahua.cn/article/gddcei.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流