1 缓冲区的分类 ByteBufferjvm
CharBuffer大数据
ShortBuffercdn
IntBuffer索引
LongBufferip
FloatBuffer内存
DoubleBufferci
2 ByteBuffer读取数据的操做 容量(capacity):表示Buffer最大数据容量,缓冲区容量不能为负,而且创建后不能修改。 限制(limit): 位于limit后的数据不能够读写。缓冲区的限制不能为负,而且不能大于其容量(capacity)。 位置(position):下一个要读取或写入的数据的索引。缓冲区的位置不能为负,而且不能大于其限制(limit)。 标记(mark)与重置(reset):标记是一个索引,经过Buffer中的mark()方法指定Buffer中一个特定的position,以后能够经过调用reset()方法恢复到这个position。get
3 ByteBuffer经常使用的操做it
put给缓冲区添加数据io
get()从缓冲区获取数据
flip();开启读模式
mark 添加标记
reset 恢复到mark的位置
clear 初始化3
4 直接缓冲区与非直接缓冲区 非直接缓冲区:经过 allocate() 方法分配缓冲区,将缓冲区创建在 JVM 的内存中 (通过物理内存到jvm内存的数据拷贝,效率低) 直接缓冲区:经过 allocateDirect() 方法分配直接缓冲区,将缓冲区创建在物理内存中。能够提升效率 (零拷贝,效率高)
5 Channel(管道) 通道表示打开到 IO 设备(例如:文件、套接字)的链接 Channel 负责传输数据, Buffer 负责存储数据 channel相似与传统io的流,只不过流是单向的,channel是双向的
6 Channel的分类
FileChannel
SocketChannel
ServerSocketChannel
DatagramChannel
有须要Java资料的能够加我