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

摘自 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代码块中。

posted @ 2016-06-18 11:05  自由石匠  阅读(642)  评论(0编辑  收藏  举报