4.NIO
4.1 NIO的概念
NIO是NO Blocking IO的缩写,它的交互方式是同步非阻塞的方式。
4.2 BIO的特点
程序的IO操作的完成的状态是一致的,即便某个连接的读写动作未完成(如数据未准备就绪),也不会阻塞其它连接的读写动作。相对BIO而言,NIO具有效率高,但由于频繁的切换线程上下文,会影响CPU性能的特点。
4.3 NIO的重要组件
Channel(通道)、Buffer(缓冲区)、Selector(多路复用器)是NIO的三元素,也是最重要的组件。实现原理,它只需两个线程就能实现,一个线程将Selector注册到Channel上,另一个线程让Selector去监听并处理它感兴趣的激活连接事件。
4.4 NIO的特点展示和底层原理
NIO特点:
程序的IO操作的完成的状态是一致的,即便某个连接的读写动作未完成,也不会阻塞其它连接的读写动作。
案例:
1.IO模式是NIO模式,
2.服务器端不关闭不停接收客户端的数据,并返回接收结果给客户端
3.ClientA不关闭不断发送数据给服务端,ClientB和ClientC发送一句话给服务端。
// 服务端程序
/**
NIO三要素
1.Channel(通道),
2.Buffer(缓冲区),
3.Selector(多路复用器).
实现原理:
一个线程将Selector注册到Channel上,一个线程让Selector管理连接事件
*/
public class NIOServer implements Runnable {
private Selector selector;
private ServerSocketChannel serverChannel;
// 一个线程将Selector注册到Channel上
public NIOServer(int port) {
try {
serverChannel = ServerSocketChannel.open();
serverChannel.bind(new InetSocketAddress(port));
serverChannel.configureBlocking(false);
selector = Selector.open();
serverChannel.register(selector, SelectionKey.OP_ACCEPT);
} catch (Exception e) {
e.printStackTrace();
}
}
// 一个线程让Selector管理连接事件
public void run() {
try {
int count = 0;
while (true) {
selector.select();
Iterator<SelectionKey> keys = selector.selectedKeys().iterator();
while (keys.hasNext()) {
SelectionKey key = keys.next();
keys.remove();
if (key.isAcceptable()) {
handlerAccept();
}