Java NIO 核心知识总结
NIO简介
在传统的I/O模型中,是以阻塞的方式进行的也就是当一个线程执行的时候线程会一直阻塞到完成工作为止。这种模型的缺点就是在并发比较大的时候性能就会比较低,并且在每次都要给一个新的任务(连接)创建一个新的线程,这个新的线程的创建和从上一个切换到这一个线程都会都性能有影响。
为了优化这个传统的io模型,在jdk1.4新引入了一个全新的new io包,在原有代码的基础上提供了非阻塞、面向缓冲、基于通道的I/O,可以使用少量的线程处理大量的连接,提高了IO的效率和并发。
attention!
使用NIO不一定就 🟰 高性能,nio的性能优势在于高并发和高延迟的的环境。
在普通的环境中NIO不一定会比传统的io效率高。
NIO的三个核心组件
**Buffer(缓冲区):**NIO读数据的时候都是到buffer区里面进行操作的,read
的时候将channel里面的数据填充到buffer里面中,写操作就是将buffer中的数据写入到channel中
**Channel(通道):**这是一个双向的,可读可写的数据传输通道,nio通过channel来实现数据的输入和输出,这个channel是一个抽象的概念。
**Selector(选择器):**允许一个线程处理多个channel,基于事件来驱动的I/O多路复用模型,所有的channel都可以注册到selector中