码迷,mamicode.com
首页 > 其他好文 > 详细

文件IO函数和标准IO库的区别

时间:2016-06-18 11:37:43      阅读:170      评论:0      收藏:0      [点我收藏+]

标签:

摘自 http://blog.chinaunix.net/uid-26565142-id-3051729.html

1,文件IO函数,在Unix中,有如下5个:open,read,write,lseek,close。称之为不带缓存的IO(unbuffered I/O)。不带缓存指的是每个read,write都调用内核中的一个系统调用。

2,标准IO库,由ANSI C标准说明。标准IO库处理很多细节。例如缓存分配,以优化长度执行IO等。标准的IO提供了三种类型的缓存。

(1)全缓存:当填满标准IO缓存后才进行实际的IO操作。

(2)行缓存:当输入或输出中遇到新行符时,标准IO库执行IO操作。

(3)不带缓存:stderr就是了。

3,缓存有什么好处呢?

可以把程序向输出流写数据比做从北京运送烤鸭到上海。如果没有缓冲区,那么每执行一次write(int b)方法,仅仅把一只烤鸭从北京运到上海,如果由一万只烤鸭,就要运送一万次,这样的运送效率显然很低。为了减少运送次数,可以先把一批烤鸭装到一个集装箱中,这样就能成批的运送烤鸭,这个集装箱就是缓冲区。

在默认的情况下,只有当这个集装箱装满后,才会把这箱烤鸭运到上海(全缓存),而flush方法表示不管集装箱是否装满,都执行一次运货操作。

为了保证输入流和输出流被及时关闭,最好把关闭流的操作放到finally代码块中。

文件IO函数和标准IO库的区别

标签:

原文地址:http://www.cnblogs.com/renchong/p/5595862.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!