java8中NIO缓冲区(Buffer)的数据存储详解
java8新特性NIO缓冲区(Buffer)的数据存储。
ByteBuffer,CharBuffer,ShortBuffer,IntBuffer,LongBuffer,FloatBuffer,
DoubleBuffer.
1、缓冲区在java nio中负责数据的存储。缓冲区就是数组。用于存储不同数据类型的数据。根据数据类型不同(boolean除外),提供了相应类型的缓冲区。
ByteBuffer,CharBuffer,ShortBuffer,IntBuffer,LongBuffer,FloatBuffer,
DoubleBuffer.
上述缓冲区的管理方式几乎一致,通过allocate()获取缓冲区。
//分配一个指定大小的缓冲区ByteBuffer byteBuffer = ByteBuffer.allocate(1024);

2、缓冲区中的四个核心属性:
capacity:容量,表示缓冲区中最大存储数据的容量。一旦声明不能改变。


3、limit:界限,表示缓冲区中可以操作数据的大小。(limit后所得数据不能进行读写)。


4、position:位置,表示缓冲区中正在操作数据的位置。
position<=limit<=capacity


5、ByteBuffer的基本使用。
缓冲区存取数据的两个核心方法:
put():存入数据到缓冲区
//分配一个指定大小的缓冲区
ByteBuffer byteBuffer = ByteBuffer.allocate(1024);
System.out.println(byteBuffer.position());
System.out.println(byteBuffer.limit());;
System.out.println(byteBuffer.capacity());
//利用put方法存入数据到缓冲区中
String str = "abcde";
byteBuffer.put(str.getBytes());



6、ByteBuffer的基本使用。
缓冲区存取数据的两个核心方法:
get():获取缓冲区的数据
//4、利用get()读取缓冲区的数据
byte[] dst = new byte[byteBuffer.limit()];
byteBuffer.get(dst);
System.out.println(new String(dst,0,dst.length));

7、调用flip()读数据模式之后
//3、切换成读取数据模式byteBuffer.flip();


8、调用flip()操作之后:

9、rewind()方法:可重复读:
byteBuffer.rewind();
System.out.println("----------rewind()-------------");
System.out.println(byteBuffer.position());
System.out.println(byteBuffer.limit());;
System.out.println(byteBuffer.capacity());


上一篇:Spring Boot集成Java DSL的实现代码
栏 目:JAVA代码
下一篇:基于Java实现记事本功能
本文标题:java8中NIO缓冲区(Buffer)的数据存储详解
本文地址:http://www.codeinn.net/misctech/85686.html


阅读排行
- 1Java Swing组件BoxLayout布局用法示例
- 2java中-jar 与nohup的对比
- 3Java邮件发送程序(可以同时发给多个地址、可以带附件)
- 4Caused by: java.lang.ClassNotFoundException: org.objectweb.asm.Type异常
- 5Java中自定义异常详解及实例代码
- 6深入理解Java中的克隆
- 7java读取excel文件的两种方法
- 8解析SpringSecurity+JWT认证流程实现
- 9spring boot里增加表单验证hibernate-validator并在freemarker模板里显示错误信息(推荐)
- 10深入解析java虚拟机




