全缓存、行缓存和无缓存
2016-07-06 19:28
169 查看
在标准I/O中,核心对象是流。所谓流,它是一个过程,所有的I/O操作都是简单的从程序的移进或移出,我们把这种字符流叫做流。标准I/O基于流的操作都是缓存文件系统。
缓存类型分为三种,分别是全缓存、行缓存和无缓存。
全缓存:填满标准I/O缓存区才进行实际的I/O操作。磁盘上的了件用标准I/O打开,默认都是全缓存的。当缓存区填满或者进行flush操作时候才会进行磁盘操作。
行缓存:当输入输出遇到换行符时候就是行缓存了。标准输入和标准输出都是行缓存。
无缓存:不对I/O操作进行缓存,对流的读写可以立即操作实际文件。典型例子就是标准出错。
下面通过一个例子解释一下行缓存:
这样一个标准输出程序,显然运行结果是向屏幕打印一句:hello。但是如果我们改一下:
这样就不会向屏幕打印“hello”。这是因为标准输出是行缓存,如果没有遇到“\n”,则需要写满缓存区才能执行I/O操作。第一个程序当之行结束,系统会自动清理缓存区,所以可以打印字符。而第二个程序,因为加入死循环,程序不会终止,系统不能清理缓存区,同时,行缓存的缓存区大小为1024,而要打印的字符显然无法填满缓存区,所以无法打印。
那么怎么修改可以打印呢?1:在标准输出内加上换行符;2:用一个for循环,是标准输出要打印的字符达到1024;3:在标准输出下加上fclose(stdout)。因为flose隐藏了fflush,可以把缓存区内容发送到终端;4:修改缓存方式。调用setvbuf函数,将缓存类型改为无缓存。 setvbuf(stdout,
NULL, _IONBF, 0);
缓存类型分为三种,分别是全缓存、行缓存和无缓存。
全缓存:填满标准I/O缓存区才进行实际的I/O操作。磁盘上的了件用标准I/O打开,默认都是全缓存的。当缓存区填满或者进行flush操作时候才会进行磁盘操作。
行缓存:当输入输出遇到换行符时候就是行缓存了。标准输入和标准输出都是行缓存。
无缓存:不对I/O操作进行缓存,对流的读写可以立即操作实际文件。典型例子就是标准出错。
下面通过一个例子解释一下行缓存:
这样一个标准输出程序,显然运行结果是向屏幕打印一句:hello。但是如果我们改一下:
这样就不会向屏幕打印“hello”。这是因为标准输出是行缓存,如果没有遇到“\n”,则需要写满缓存区才能执行I/O操作。第一个程序当之行结束,系统会自动清理缓存区,所以可以打印字符。而第二个程序,因为加入死循环,程序不会终止,系统不能清理缓存区,同时,行缓存的缓存区大小为1024,而要打印的字符显然无法填满缓存区,所以无法打印。
那么怎么修改可以打印呢?1:在标准输出内加上换行符;2:用一个for循环,是标准输出要打印的字符达到1024;3:在标准输出下加上fclose(stdout)。因为flose隐藏了fflush,可以把缓存区内容发送到终端;4:修改缓存方式。调用setvbuf函数,将缓存类型改为无缓存。 setvbuf(stdout,
NULL, _IONBF, 0);
相关文章推荐
- 人体的组成
- Java+利用UDP实现简单双机通信
- C#之WCF
- Eclipse工程导入,找不到工程问题
- 初识gcc编译过程
- 双链表的C语言实现
- 并发编程学习总结(八) :java中synchronized关键字使用详解 对象锁的相关条件的使用(2)
- C++20、友元类
- 欢迎使用CSDN-markdown编辑器
- 如何将格式为byte[]的图片保存在本地
- 循环链表的C语言实现
- Linux下Web网站压力测试工具Webbench
- oracle用expdp定时备份所有步骤详解[转]
- UVA 1262 Password
- Golang的包依赖管理 (package dependency manager)
- poj 1062 dijkstra求最短路变形
- 链接全过程
- 微信公众平台开发教程第21篇-“可信网址”白名单
- 基于Matlab的自动控制原理 计算传递函数的零极点
- mysql的partition分区