NIO family 一览

一、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当中

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章