Java NIO 之缓冲区

本文详细介绍了Java NIO中的缓冲区概念及其使用方法。包括如何通过allocate()方法创建缓冲区,利用put()方法写入数据,get()方法读取数据。此外还解释了缓冲区的四个核心属性:capacity、limit、position及mark,并通过实例演示了flip()、rewind()和clear()等常用操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、缓冲区(Buffer)

在NIO中负责数据的存取。缓冲区就是数组,用于存储不同数据类型的数据,根据数据类型不同(boolean除外),提供了相应类型的缓冲区:ByteBuffer,CharBuffer,ShortBuffer,IntBuffer,LongBuffer,FloatBuffer,DoubleBuffer。

①管理方式基本一致,通过allocate()获取缓冲区

ByteBuffer buf = ByteBuffer.allocate(512);

②缓冲区存取数据的方法:

put():存入数据到缓冲区

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

③缓冲区四个核心属性

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

limit:界限,缓冲区中可以操作数据的大小,(limit后的数据不能读写)

position:位置,缓冲区中正在操作的位置

mark:标记,表示记录当前position的位置。可以通过reset()恢复到mark的位置

mark <= position <= limit <= capacity

测试代码:

String str = "12345";

ByteBuffer buf = ByteBuffer.allocate(512);//分配制定大小的缓冲区

System.out.println(buf.position());//0
System.out.println(buf.limit());//512
System.out.println(buf.capacity());//512

buf.put(str.getBytes());//将数据放入缓冲区

System.out.println(buf.position());//5
System.out.println(buf.limit());//512
System.out.println(buf.capacity());//512

buf.flip();//切换成读取数据模式

System.out.println(buf.position());//0
System.out.println(buf.limit());//5
System.out.println(buf.capacity());//512

byte[] des = new byte[buf.limit()];
buf.get(des);//读取缓冲区数据
System.out.println(new String(des,0,des.length));//12345

System.out.println(buf.position());//5
System.out.println(buf.limit());//5
System.out.println(buf.capacity());//512

buf.rewind();//可重复读

System.out.println(buf.position());//0
System.out.println(buf.limit());//5
System.out.println(buf.capacity());//512

buf.clear();//清空缓冲区,但是缓冲区的数据依然存在,处于“被遗忘”状态

System.out.println(buf.position());//0
System.out.println(buf.limit());//512
System.out.println(buf.capacity());//512

System.out.println((char) buf.get());//1 说明数据依然存在



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值