1 缓冲区的分类
ByteBuffer
CharBuffer
ShortBuffer
IntBuffer
LongBuffer
FloatBuffer
DoubleBuffer
2 ByteBuffer读取数据的操作
容量(capacity):表示Buffer最大数据容量,缓冲区容量不能为负,并且建立后不能修改。
限制(limit): 位于limit后的数据不可以读写。缓冲区的限制不能为负,并且不能大于其容量(capacity)。
位置(position):下一个要读取或写入的数据的索引。缓冲区的位置不能为负,并且不能大于其限制(limit)。
标记(mark)与重置(reset):标记是一个索引,通过Buffer中的mark()方法指定Buffer中一个特定的position,之后可以通过调用reset()方法恢复到这个position。
3 ByteBuffer常用的操作
put给缓冲区添加数据
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
热门工具 换一换