一、Buffer缓冲区
用户数据处理的基础单元,客户端发送与接收数据都需要通过Buffer转发进行
二、Channel通道
类似于流;但不同于IN/OUT Stream;流具有独占性与单向性;通道则偏向于数据的流通多样性
三、Selectors选择器
处理客户端所有事件的分发器
四、Charset扩展部分
Charset字符编码:加密、解密
原生支持的、数据通道级别的数据处理方式,可以用于数据传输级别的数据加密、解密等操作
五、NIO-Buffer
Buffer包括
ByteBuffer、CharBuffer、ShortBuffer、IntBuffer、LongBuffer、FloatBuffer、DoubleBuffer
与传统不同,写数据时先写到Buffer->Channel;读则反之
与传统不同,写数据时先写到Buffer->Channel;读则反之
为NIO块状操作提供基础,数据都按“块”进行传输
一个Buffer代表一“块”数据
六、NIO-Channel
可从通道中获取数据也可输出数据到通道;按“块” Buffer进行
可并发可异步读写数据(但是当数据是有序时,如果使用多线程中间加了其它的数据,可能会导致数据不可用。所以,一般读是一个线程,写是一个线程)
读数据时读到Buffer,写数据则必须通过Buffer写数据
包括:FileChannel、SocketChannel、DatagramChannel等
七、NIO职责
首先,向Selector注册Channel的可读、可写状态
当客户端向服务端发送消息,网卡收到消息后,Channel处于可读状态,Selector收到通知,Channel收到消息,将数据读取到Buffer当中