IO与NIO的区别
IO是面向流的而NIO是面向缓冲区的,IO是阻塞的NIO是非阻塞的,NIO有选择器,IO没有。其中NIO的非阻塞和选择器是对于网络传输而言的。
NIO的核心
java的NIO的核心在于通道(Channel)和缓冲区(Buffer)。通道表示在打开到IO设备(例如文件,套接字)的连接,若要使用java NIO系统,需要获取用于连接IO设备的通道以及用于容纳数据的缓冲区。然后操作缓冲区对数据处理。简而言之:Channel负责传输,而Buffer负责存储。
NIO之缓冲区
capacity:容量指的是最大存储数据的容量
limit:界限,表示缓冲区中可以操作数据的大小(limit后面的不能进行读写)
position:表示缓冲去中正在操作的数据的位置
position<=limit<=capacity
NIO之通道
通道(channel)表示IO源与目标打开的连接,channel类似于传统的“流”,只不过channel本身不能直接访问数据,Channel本身不能直接访问数据,Channel只能与Buffer进行交互。
NIO的直接缓冲区和非直接缓冲区
非直接缓冲区:通过allocate()方法分配缓冲区,将缓冲区建立在JVM的内存中
直接缓冲区:通过allocateDirect()方法直接分配缓冲区,将缓冲区建立在物理内存中,可以提高效率