JAVA的NIO模型
什么是NIO
java的NIO全称为non-blocking IO,使用它可以提供非阻塞式的高伸缩性网络
NIO的基本组成
NIO主要有三部分:Channel、Buffer和Selector
Channel是一个对象,可以用过它进行数据的读取和写入,它是面向缓冲区的,所有的数据都通过Buffer来处理,永远不会直接将字节写入通道中,而是将数据写入包含一个字节或者多个字节的缓冲区
早多线程模式下,阻塞IO时,一个线程只能处理一个请求,比如Http请求,当请求响应式关闭连接,释放线程资源。Selector选择器的作用就是配合一个线程来管理多个Channel,获取这些Channel上发生的事件,这些Channel工作在非阻塞模式下,不会让线程一直在一个Channel上,适合连接数特别多,但流量低的场景
调用Selector的select()方法会阻塞直到Channel发送了读写就绪事件,这些事件发生,select()方法就会返回这些事件交给thread来处理。