JAVA的IO操作接口:
1.基于字节操作的IO接口:InputStream和OutputStream;
2.基于字符操作的IO接口:Writer和Reader;
3.基于磁盘操作的IO接口:File;
4.基于网络的IO接口:Socket;
数据传输和持久化都是以字节进行的,因此必须具备有字符到字节或是字节到字符的转化。
磁盘I/O的工作机制:
读取和写入文件IO都需要调用操作系统提供的接口,而只要是系统调用就可能存在内核空间地址和用户空间地址切换的问题。访问文件的方式主要有以下五种:1)标准访问文件方式,注意此时写对应的是写缓存,由操作系统控制写磁盘;2)直接I/O方式,直接访问磁盘数据,减少一次内核缓存到用户缓存之间的数据的复制,如数据库的操作;3)同步访问方式;4)异步访问文件方式;5)内存映射方式。
网络响应时间:网络带宽、传输距离、TCP拥塞控制
计算机网络(TCP/IP连接)JAVA IO
NIO的工作方式
数据在写入OutputStream或者是读取InputStream都有可能引起阻塞,阻塞之后,线程将失去CPU的使用权。主要涉及到Buffer、Channel、Selector三个类。
NIO的数据访问方式
NIO有两种优化方法:FileChannel.TransferXXX()和
FileChannel.map,其中map方法可以在一个打开的文件和一个特殊
类型的ByteBuffer之间建立一个虚拟内存映射。在FileChannel上调用map()方法会创建一个由磁盘文件支持的虚拟内存映射并在那块虚拟内存空间外部封装一个MappedByteBuffer对象。所有的MappedByteBuffer对象都是直接的。具体内容http://blog.csdn.net/liuxu93466/article/details/7475652