标准IO 是通过new File的方式访问, 这种方式的访问会先把磁盘的文件缓存到操作系统层面,再有操作系统缓存到应用程序层面(Java程序层面),这种访问最慢。

直接IO是略过操作系统层面,直接访问文件进行文件的读写,减少了磁盘缓冲到操作系统层面。Java中是由DirectByteBuffer,但是这种机制的缺点也是有的,对于没有做好一个好的程序缓存管理,或者一直需要读取新的文件的时候,还是需要直接从磁盘读取文件。

内存映射的方式是通过一个内存映射文件,这个文件映射了操作系统内存与磁盘文件的映射的关系,比如 内存a1-a100区间 对应 1-100M文件地址。 每一次访问内存就是要访问磁盘文件。当然这是由操作系统完成的,操作系统会预加载一些数据到缓冲区。这种也没有操作系统到应用程序的复制。因为操作系统和应用程序共享这一段的数据,可以进行一些大文件的处理。

参考:
1. http://www.cnblogs.com/androidsuperman/p/7083049.html
2. http://www.cnblogs.com/hapjin/p/5736188.html
3. http://blog.csdn.net/qq_29134495/article/details/51519334
4. http://www.cnblogs.com/huanxiyun/articles/5443754.html


本文转载:CSDN博客