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


猜你喜欢

转载自blog.csdn.net/tt8889/article/details/124594130