所有类


java.nio
类 Buffer

java.lang.Object
  继承者 java.nio.Buffer
直接已知子类:
ByteBuffer, CharBuffer, DoubleBuffer, FloatBuffer, IntBuffer, LongBuffer, ShortBuffer

public abstract class Buffer
   
   
   
   
   
extends Object

一种用于特定的基本类型数据的容器。

缓冲区是特定的基本类型元素的线性、有限序列。缓冲区的基本属性除其内容外还包括容量、限制和位置:

缓冲区的容量 是它所包含的元素的数量。缓冲区的容量永远不会为负并且从不会更改。

缓冲区的限制 是不应读取或写入的第一个元素的索引。缓冲区的限制永远不会为负,并且永远不会大于其容量。

缓冲区的位置 是下一个要读取或写入的元素的索引。缓冲区的位置永远不会为负,并且永远不会大于其限制。

每个非 boolean 基本类型都存在此类的一个子类。

传输数据

此类的每个子类都定义了两种 getput 操作:

相对 操作读取或写入从当前位置开始的一个或多个元素,然后将该位置增加传输的元素的数量。如果请求的传输超过了限制,则相对 get 操作将抛出 BufferUnderflowException,相对 put 操作将抛出 BufferOverflowException;但无论哪种情况,都不传输数据。

绝对 操作采用显式元素索引,不会影响位置。如果索引参数超过了该限制,则绝对 getput 操作将抛出 IndexOutOfBoundsException

当然,通过适当信道的 I/O 操作还可以将数据传输到缓冲区或从中传出数据(是传入还是传出,通常与当前位置有关)。

做标记和重置

缓冲区的标记 是在调用 reset 方法时其位置将被重置的索引。并不是总要定义标记,但是,在定义标记时,永远不要将其定义为负数,并且永远不要大于其位置。如果定义了标记,则在位置或限制调整为小于标记的值时,该标记将被丢弃。如果未定义标记,则调用 reset 方法将导致抛出 InvalidMarkException

不变式

下面的不变式持有标记、位置、限制和容量值:

0<=标记<=位置<=限制<=容量

新创建的缓冲区总有一个零位置和一个未定义的标记。初始限制可以为零,也可以是其他某个值,这取决于缓冲区类型及其构建方式。一般情况下,缓冲区的初始内容未定义。

清除、反转和重绕

除了访问位置、限制、容量值以及做标记和重置等方法外,此类还对缓冲区定义了以下操作:

  • clear() 使缓冲区做好了新序列信道读取或相对 put 操作的准备:它将限制设置为容量大小,将位置设置为零。

  • flip() 使缓冲区做好了新序列信道读取或相对 get 操作的准备:它将限制设置为当前位置,然后将该位置设置为零。

  • rewind() 使缓冲区做好了重新读取已包含的数据的准备:它使限制保持不变,并将位置设置为零。

只读缓冲区

每个缓冲区都是可读取的,但并非每个缓冲区都是可写入的。每个缓冲区类的 mutation 方法都被指定为可选操作,当调用只读缓冲区时,将抛出 ReadOnlyBufferException。只读缓冲区不允许更改其内容,但其标记、位置和限制值可以改变。缓冲区是否为只读通过调用其 isReadOnly 方法决定。

线程安全

缓冲区由当前的多个线程使用是不安全的。如果一个缓冲区由不止一个线程使用,则应该通过适当的同步来控制对该缓冲区的访问。

调用连接

指定此类中的方法(它们不返回其他值)以返回这些方法被调用时所在的缓冲区。此操作允许方法调用被连接;例如,语句序列

 b.flip();
 b.position(23);
 b.limit(42);
可以由下面单个、更紧凑的语句代替
 b.flip().position(23).limit(42);

从以下版本开始:
1.4

方法摘要
 intcapacity()
          返回此缓冲区的容量。
 Bufferclear()
          清除此缓冲区。
 Bufferflip()
          反转此缓冲区。
 booleanhasRemaining()
          判断在当前位置和限制之间是否有任何元素。
abstract  booleanisReadOnly()
          判断此缓冲区是否为只读缓冲区。
 intlimit()
          返回此缓冲区的限制。
 Bufferlimit(int newLimit)
          设置此缓冲区的限制。
 Buffermark()
          在此缓冲区的位置设置其标记。
 intposition()
          返回此缓冲区的位置。
 Bufferposition(int newPosition)
          设置此缓冲区的位置。
 intremaining()
          返回当前位置与限制之间的元素数量。
 Bufferreset()
          将此缓冲区的位置重新设置成以前标记的位置。
 Bufferrewind()
          重绕此缓冲区。
 
从类 java.lang.Object 继承的方法
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

方法详细信息

capacity

public final int capacity()
返回此缓冲区的容量。

返回:
此缓冲区的容量

position

public final int position()
返回此缓冲区的位置。

返回:
此缓冲区的位置

position

public final Buffer position(int newPosition)
设置此缓冲区的位置。如果标记已定义并且大于新的位置,则要丢弃该标记。

参数:
newPosition - 新位置值;必须为非负并且不能大于当前限制
返回:
此缓冲区
抛出:
IllegalArgumentException - 如果关于 newPosition 的前提不成立

limit

public final int limit()
返回此缓冲区的限制。

返回:
此缓冲区的限制

limit

public final Buffer limit(int newLimit)
设置此缓冲区的限制。如果位置大于新的限制,则它被设置为此新限制。如果标记已定义并且大于新限制,则要丢弃该标记。

参数:
newLimit - 新限制值;必须为非负并且不能大于此缓冲区的容量
返回:
此缓冲区
抛出:
IllegalArgumentException - 如果关于 newLimit 的前提不成立

mark

public final Buffer mark()
在此缓冲区的位置设置其标记。

返回:
此缓冲区

reset

public final Buffer reset()
将此缓冲区的位置重新设置成以前标记的位置。

调用此方法既不会更改也不会丢弃标记的值。

返回:
此缓冲区
抛出:
InvalidMarkException - 如果尚未设置标记