NIO之缓冲区【复制缓冲区】

[](()duplicate

--------------------------- 《一线大厂Java面试题解析+后端开发学习笔记+最新架构讲解视频+实战项目源码讲义》无偿开源 威信搜索公众号【编程进阶路】 --------------------------------------------

函数创建了一个与原始缓冲区相似的新缓冲区。两个缓冲区共享数据元素,拥有同样的容量,但每个缓冲区拥有各自的位置,上界和标记属性。对一个缓冲区内的数据元素所做的改变会反映在另外一个缓冲区上。这一副本缓冲区具有与原始缓冲区同样的数据视图。如果原始的缓冲区为只读,或者为直接缓冲区,新的缓冲区将继承这些属性。

public static void main(String[] args) {

CharBuffer charbuffer1 = CharBuffer.allocate(10);

CharBuffer charbuffer2 = charbuffer1.duplicate();

charbuffer1.put(‘a’).put(‘b’).put(‘c’);

charbuffer1.flip();

System.out.println(charbuffer1+“–”+charbuffer1.capacity()+" “+charbuffer1.limit()+” "+charbuffer1.position());

System.out.println(charbuffer2+“–”+charbuffer2.capacity()+" “+charbuffer2.limit()+” "+charbuffer2.position());

}

输出结果

abc–10 3 0

abc --10 10 0

在这里插入图片描述

[](()asReadOnlyBuffer


asReadOnlyBuffer()函数来生成一个只读的缓冲区视图,这与duplicate()相同,除了这个新的缓冲区不允许使用put(),并且其isReadOnly()函数将会返回true。对这一只读缓冲区的put()函数的调用尝试会导致抛出ReadOnlyBufferException异常。

public static void main(String[] args) {

CharBuffer charbuffer1 = CharBuffer.allocate(10);

CharBuffer charbuffer2 = charbuffer1.asReadOnlyBuffer();

charbuffer1.put(‘a’).put(‘b’).put(‘c’);

charbuffer1.flip();

System.out.println(charbuffer1);

System.out.println(charbuffer2);

charbuffer2.put(“d”);

}

输出:

abc

abc

Exception in thread “main” java.nio.ReadOnlyBufferException

at java.nio.CharBuffer.put(Unknown Source)

at java.nio.CharBuffer.put(Unknown Source)

at com.sxt.nio.Demo02.main(Demo02.java:14)

[](()slice


Java NIO(New Input/Output)是 Java 1.4 引入的一套新的 I/O 库,旨在提高 Java 程序的 I/O 性能,其中缓冲区(Buffer)是 Java NIO 中的核心组件之一,为数据的读写提供了高效的存储和操作方式[^1]。 ### 介绍 在 Java NIO 中,Buffer 负责在 Java 虚拟机内存中存储数据,提供了一种结构化的方式来存储数据,以便更高效地进行 IO 操作。与传统的流式 IO 不同,NIO 采用面向缓冲区的方式,数据先读入一个缓冲区,然后再从缓冲区中读取或写入,操作更为灵活,也更容易进行数据操作和管理[^2]。 ### 使用方法 以下是一个简单的 Java NIO 缓冲区使用示例: ```java import java.nio.IntBuffer; public class BufferExample { public static void main(String[] args) { // 创建一个容量为 10 的 IntBuffer IntBuffer buffer = IntBuffer.allocate(10); // 写入数据到缓冲区 for (int i = 0; i < 5; i++) { buffer.put(i); } // 切换到读取模式 buffer.flip(); // 从缓冲区读取数据 while (buffer.hasRemaining()) { System.out.print(buffer.get() + " "); } // 清空缓冲区,准备下一次写入 buffer.clear(); } } ``` 上述代码中,首先使用 `allocate` 方法创建一个容量为 10 的 `IntBuffer`,然后使用 `put` 方法向缓冲区写入数据,接着使用 `flip` 方法将缓冲区从写入模式切换到读取模式,再使用 `get` 方法从缓冲区读取数据,最后使用 `clear` 方法清空缓冲区。 ### 特性 - **高效性**:Java NIO 采用面向缓冲区的方式进行 IO 操作,数据先读入缓冲区,再从缓冲区读取或写入,减少了数据的复制次数,提高了 IO 性能[^2]。 - **灵活性**:缓冲区提供了多种操作方法,如 `put`、`get`、`flip`、`clear` 等,可以方便地进行数据的读写和管理[^1]。 - **可重用性**:缓冲区可以被重复使用,通过 `clear` 或 `compact` 方法可以清空或压缩缓冲区,准备下一次的读写操作。 - **非阻塞 IO**:Java NIO 基于非阻塞 IO 模型,结合选择器(Selector)可以实现高效的并发 IO 操作,提高系统的并发处理能力[^3]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值