欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

java8中NIO缓冲区(Buffer)的数据存储详解

程序员文章站 2024-02-23 12:20:52
java8新特性nio缓冲区(buffer)的数据存储。 bytebuffer,charbuffer,shortbuffer,intbuffer,longbuffer,f...

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);

java8中NIO缓冲区(Buffer)的数据存储详解

2、缓冲区中的四个核心属性:

capacity:容量,表示缓冲区中最大存储数据的容量。一旦声明不能改变。

java8中NIO缓冲区(Buffer)的数据存储详解

java8中NIO缓冲区(Buffer)的数据存储详解

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

java8中NIO缓冲区(Buffer)的数据存储详解

java8中NIO缓冲区(Buffer)的数据存储详解

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

position<=limit<=capacity

java8中NIO缓冲区(Buffer)的数据存储详解

java8中NIO缓冲区(Buffer)的数据存储详解

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());

java8中NIO缓冲区(Buffer)的数据存储详解

java8中NIO缓冲区(Buffer)的数据存储详解

java8中NIO缓冲区(Buffer)的数据存储详解

6、bytebuffer的基本使用。

缓冲区存取数据的两个核心方法:

get():获取缓冲区的数据

 

//4、利用get()读取缓冲区的数据

    byte[] dst = new byte[bytebuffer.limit()];

    bytebuffer.get(dst);

    system.out.println(new string(dst,0,dst.length));

java8中NIO缓冲区(Buffer)的数据存储详解

7、调用flip()读数据模式之后

//3、切换成读取数据模式bytebuffer.flip();

java8中NIO缓冲区(Buffer)的数据存储详解

java8中NIO缓冲区(Buffer)的数据存储详解

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

java8中NIO缓冲区(Buffer)的数据存储详解

9、rewind()方法:可重复读:

bytebuffer.rewind();

system.out.println("----------rewind()-------------");

system.out.println(bytebuffer.position());

system.out.println(bytebuffer.limit());;

system.out.println(bytebuffer.capacity());

java8中NIO缓冲区(Buffer)的数据存储详解

java8中NIO缓冲区(Buffer)的数据存储详解