缓冲区:在javaNIO中负责数据的存取,缓冲区就是数组,用于存储不同数据类型的数据
根据数据类型的不同,提供了相应的缓存区
BteBuffer
CharBuffer
ShortBuffer
IntBuffer
LongBuffer
FloatBuffer
DoubleBuffer
上述缓存区的管理方式一致,通过allocate()获取缓存区
缓存区中的的核心属性:
1.capacity:表示缓存区最大数据容量,一旦声明不能更改
2.limit:表示缓存区中可以操作的数据大小(limit后数组不能进行读写)
3.position:表示缓存区中正在操作数据的位置
4.position<=limit<=capcity
remark 标记,表示记录当前position的位置,可以通过reset()恢复到mark的位置
直接缓存区与非直接缓存区
非直接缓存区:通过allocate方法分配缓冲区,将缓冲区建立在jvm的内存中
根据数据类型的不同,提供了相应的缓存区
BteBuffer
CharBuffer
ShortBuffer
IntBuffer
LongBuffer
FloatBuffer
DoubleBuffer
上述缓存区的管理方式一致,通过allocate()获取缓存区
缓存区中的的核心属性:
1.capacity:表示缓存区最大数据容量,一旦声明不能更改
2.limit:表示缓存区中可以操作的数据大小(limit后数组不能进行读写)
3.position:表示缓存区中正在操作数据的位置
4.position<=limit<=capcity
remark 标记,表示记录当前position的位置,可以通过reset()恢复到mark的位置
直接缓存区与非直接缓存区
非直接缓存区:通过allocate方法分配缓冲区,将缓冲区建立在jvm的内存中
直接缓冲区:通过allocateDirect()方法分配直接缓冲区,将缓冲建立在物理内存中,可以提高效率
//put():存入数据到缓存区
//get():从缓存区获取数据
public void test() {
//1.分配一个指定大小的非直接缓存区
ByteBuffer buffer = ByteBuffer.allocate(1024);
String string = "abcde";
buffer.put(string.getBytes());
buffer.flip();
//判断是否是直接缓冲区
System.out.println(buffer.isDirect());
}
public void test1() {
//1.分配一个指定大小的直接缓存区
ByteBuffer buffer = ByteBuffer.allocateDirect(1024);
String string = "abcde";
buffer.put(string.getBytes());
buffer.flip();//设置可以重复读取数据
}
本文详细介绍了Java NIO中的缓冲区概念,包括各种类型的缓冲区如ByteBuffer、CharBuffer等,以及它们的核心属性如capacity、limit和position。此外还对比了直接缓冲区与非直接缓冲区的区别,并给出了具体的代码示例。
411

被折叠的 条评论
为什么被折叠?



