一、概念:NIO即New IO,这个库是在JDK1.4中才引入的。NIO和IO有相同的作用和目的,但实现方式不同,NIO主要用到的是块,所以NIO的效率要比IO高很多。
二、NIO和IO的主要区别
三、BIO的缺点
1、产生阻塞行为:receive、accept、connect、read、write。
2、一对一的连接,每连接一个客户端,就需要开启一个线程去处理,当客户端较多的时候,服务器或产生大量的线程,耗费内存。
3、连接建立之后如果不发生任何的操作,就会导致服务器中的这个线程依旧被占用,耗费服务器的资源。
4、无法实现定点操作。
四、NIO的优点
1、非阻塞,提高传输效率
2、一对多的连接:可以用一个或者少量的服务器中的线程来处理大量的请求,从而节省服务器的内存资源
3、即使已经建立连接,只要没有对应的读写事件,那么依然不能够使用服务器来进行处理
4、利用通道实现数据的双向传输
5、因为利用缓冲区来存储数据,所以可以对缓冲区的数据实现定点操作
五、NIO的三大组件
1、Buffer-缓冲区
2、Channel-通道
3、Selector-多路复用选择器
附:
public static void main(String[] args) {
// 创建缓冲区对象
// ByteBuffer底层依靠字节数组来存储数据
ByteBuffer buffer = ByteBuffer.allocate(10);
// 获取操作位
System.out.println(buffer.position());
System.out.println(buffer.capacity());
System.out.println(buffer.limit());
}