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

网友投稿 681 2022-05-29

复制缓冲区

复制一个缓冲区会创建一个新的 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( ); }

1

2

3

4

5

6

7

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()); }

1

2

3

4

5

6

7

8

9

输出结果

abc--10 3 0 abc --10 10 0

1

2

asReadOnlyBuffer

asReadOnlyBuffer()函数来生成一个

只读

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

的缓冲区视图,这与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"); }

1

2

3

4

5

6

7

8

9

输出:

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)

1

2

3

4

5

6

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()); }

1

2

3

4

5

6

7

8

9

10

11

输出

abc 0 3 10 bc 0 2 2

1

2

3

4

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:adb无线调试手机-android必备技能
下一篇:部署数据库1
相关文章