一:什么是NIO?
二:NIO三大组件
1. channel
channel 有一点类似于 stream,它就是读写数据的双向通道,可以从 channel 将数据读入 buffer,也可以将 buffer 的数据写入 channel,而之前的 stream 要么是输入,要么是输出,channel 比 stream 更为底层
2. Buffer
2.1 ByteBuffer 正确使用姿势:
(1)向 buffer 写入数据,例如调用 channel.read(buffer)
(2)调用 flip() 切换至读模式
(3)从 buffer 读取数据,例如调用 buffer.get()
(4)调用 clear() 或 compact() 切换至写模式
(5)重复 1~4 步骤
2.2 ByteBuffer 结构
capacity
position
limit
写模式下,position 是写入位置,limit 等于容量,下图表示写入了 4 个字节后的状态
读模式下,position 切换为读取位置,limit 切换为读取限制
3. Selector
selector 的作用就是配合一个线程来管理多个 channel,获取这些 channel 上发生的事件,这些 channel 工作在非阻塞模式下,不会让线程吊死在一个 channel 上。适合连接数特别多,但流量低的场景(low traffic)
三:channel与selector的关系
selector 就可以监控多个 channel 的事件