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

复制缓冲区

  复制一个缓冲区会创建一个新的 Buffer 对象,但并不复制数据。原始缓冲区和副本都会操作同样的数据元素。我们将以 CharBuffer 为例来演示,但同样的操作可被用于任何基本的缓冲区类型。

public abstract class CharBuffer extends Buffer implements CharSequence, Comparable 
{ 
 // This is a partial API listing 
 public abstract CharBuffer duplicate( ); 
 public abstract CharBuffer asReadOnlyBuffer( ); 
 public abstract CharBuffer slice( ); 
}

duplicate

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

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

  分割缓冲区与复制相似,但slice()创建一个从原始缓冲区的当前位置开始的新缓冲区,并且其容量是原始缓冲区的剩余元素数量(limit-position)。这个新缓冲区与原始缓冲区共享一段数据元素子序列。分割出来的缓冲区也会继承只读和直接属性。

public static void main(String[] args) {
       CharBuffer charbuffer1 = CharBuffer.allocate(10);
       charbuffer1.put('a').put('b').put('c');
       charbuffer1.flip();
       System.out.println(charbuffer1);
       System.out.println(charbuffer1.position()+" "+charbuffer1.limit()+" "+charbuffer1.capacity());
       charbuffer1.position(1);
       CharBuffer cb = charbuffer1.slice();
       System.out.println(cb);
       System.out.println(cb.position()+" "+cb.limit()+" "+cb.capacity());
}

输出

abc
0 3 10
bc
0 2 2

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

波波烤鸭

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值