java缓冲区

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资料的能够加我

相关文章
相关标签/搜索