文件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代码块中。