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

NIO之缓冲区【复制缓冲区】,第1张

[](()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


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/877932.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-13
下一篇 2022-05-13

发表评论

登录后才能评论

评论列表(0条)

保存