一、NIO原理
1、缓冲区
缓冲区其实就是一个数组,读取和写入都会用到缓冲器。最常用的就是ByteBuffer
2、通道
通道传输的数据是基于缓冲区的,不能直接对通道就行写或读的操作。通道和流的不同之处通道是双向的。
当读或写的事件发生时,可以从Selector获取SelectionKey,同时从key中找到发生的事件和具体的selectableChannel`
3、选择器
selector类似一个观察者,当有事件发生的时候,它会通知,传回一组selectionKey,从而定位到通道,获取数据。
selector原理是对注册的key进行轮询访问,当有事件发生的时候,就会通过Selector.select()方法进行获取事件
二、NIO与IO的区别
1、面向不同
IO是面向流的,当开始读取数据的时候,每次可以读取1个或者多个字节,直至读取完毕。之后不能移动前后的数据。
NIO是面向缓冲的,它会存到缓冲区中,可以移动前后的数据。这样的目的是确保当数据写入的时候,缓冲区中存在的数据不会被覆盖。
2、方式不同
一个是阻塞IO,一个是非阻塞IO
Java中各种流都是阻塞的。意味着当线程调用read()/write()方法的时候,线程会一直阻塞等待数据,在此期间,什么事情都做不了。
非阻塞IO 在读取的时候,如果没有可用的数据,则什么都不会获取。而不是一直阻塞,直至可以读取数据之前,该线程可以继续做其他的事情。
写数据的时候同理。所以一个单独的线程可以管理多个输入输入的通道。
3、特有的选择器
NIO的选择器允许一个单独的线程监视多个输入通道,你可以注册多个通道到一个选择器
channel和selector联合使用,必须要将channel注册到selector上,通过register()方法来实现。
只要Channel向selector注册了某个特定的事件,selector就会监听这些时间是否发生,一旦发生便会通知channel。