Package org.apache.qpid.protonj2.buffer
Class ProtonByteBuffer
- java.lang.Object
- 
- org.apache.qpid.protonj2.buffer.ProtonAbstractBuffer
- 
- org.apache.qpid.protonj2.buffer.ProtonByteBuffer
 
 
- 
- All Implemented Interfaces:
- java.lang.Comparable<ProtonBuffer>,- ProtonBuffer
 
 public class ProtonByteBuffer extends ProtonAbstractBuffer Implementation of the ProtonBuffer interface that uses an array backing the buffer that is dynamically resized as bytes are written.
- 
- 
Field SummaryFields Modifier and Type Field Description static intDEFAULT_CAPACITYThe default initial capacity used for the underlying byte array.static intDEFAULT_MAXIMUM_CAPACITYThe default maximum capacity that this buffer can grow to.- 
Fields inherited from class org.apache.qpid.protonj2.buffer.ProtonAbstractBuffermarkedReadIndex, markedWriteIndex, readIndex, writeIndex
 
- 
 - 
Constructor SummaryConstructors Modifier Constructor Description ProtonByteBuffer()Creates a newProtonByteBufferinstance that uses default configuration values for initial capacity and the maximum allowed capacity to which the underlying byte array will grow before errors will be thrown from operations that would expand the storage.ProtonByteBuffer(byte[] array)Creates a newProtonByteBufferwith the given byte array as the backing store to be used initially.protectedProtonByteBuffer(byte[] array, int maximumCapacity)protectedProtonByteBuffer(byte[] array, int maximumCapacity, int writeIndex)ProtonByteBuffer(int initialCapacity)Creates a newProtonByteBufferwith the given initial capacity and uses the default value for the maximum capacity restriction.ProtonByteBuffer(int initialCapacity, int maximumCapacity)Creates a newProtonByteBufferwith the given initial capacity and the given maximum capacity restriction.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description intcapacity()ProtonBuffercapacity(int newCapacity)Adjusts the capacity of this buffer.ProtonBuffercopy(int index, int length)Returns a copy of this buffer's sub-region.byte[]getArray()Returns the backing array for this ProtonBuffer instance if there is such an array or throws an exception if this ProtonBuffer implementation has no backing array.intgetArrayOffset()bytegetByte(int index)Gets a byte from the specified index, this method will not modify the read or write index.ProtonBuffergetBytes(int index, byte[] destination, int destinationIndex, int length)Transfers this buffer's data to the specified destination starting at the specified absoluteindex.ProtonBuffergetBytes(int index, java.nio.ByteBuffer destination)Transfers this buffer's data to the specified destination starting at the specified absoluteindexuntil the destination's position reaches its limit.ProtonBuffergetBytes(int index, ProtonBuffer destination, int destinationIndex, int length)Transfers this buffer's data to the specified destination starting at the specified absoluteindex.intgetInt(int index)Gets a int from the specified index, this method will not modify the read or write index.longgetLong(int index)Gets a long from the specified index, this method will not modify the read or write index.shortgetShort(int index)Gets a short from the specified index, this method will not modify the read or write index.booleanhasArray()ProtonBuffersetByte(int index, int value)Sets the byte value at the given write index in this buffer's backing data store.ProtonBuffersetBytes(int index, byte[] source, int sourceIndex, int length)Transfers the specified source array's data to this buffer starting at the specified absoluteindex.ProtonBuffersetBytes(int index, java.nio.ByteBuffer src)Transfers the specified source buffer's data to this buffer starting at the specified absoluteindexuntil the source buffer's position reaches its limit.ProtonBuffersetBytes(int index, ProtonBuffer source, int sourceIndex, int length)Transfers the specified source buffer's data to this buffer starting at the specified absoluteindex.ProtonBuffersetInt(int index, int value)Sets the int value at the given write index in this buffer's backing data store.ProtonBuffersetLong(int index, long value)Sets the long value at the given write index in this buffer's backing data store.ProtonBuffersetShort(int index, int value)Sets the short value at the given write index in this buffer's backing data store.java.nio.ByteBuffertoByteBuffer(int index, int length)Returns a ByteBuffer that represents the given span of bytes from the readable portion of this buffer.- 
Methods inherited from class org.apache.qpid.protonj2.buffer.ProtonAbstractBufferadjustIndexMarks, checkDestinationIndex, checkIndex, checkNewCapacity, checkReadableBytes, checkSourceIndex, clear, compareTo, copy, duplicate, ensureWritable, equals, getBoolean, getBytes, getBytes, getBytes, getChar, getDouble, getFloat, getMaxWritableBytes, getReadableBytes, getReadIndex, getUnsignedByte, getUnsignedInt, getUnsignedShort, getWritableBytes, getWriteIndex, hashCode, isOutOfBounds, isReadable, isReadable, isWritable, isWritable, markReadIndex, markWriteIndex, maxCapacity, readBoolean, readByte, readBytes, readBytes, readBytes, readBytes, readBytes, readBytes, readBytes, readDouble, readFloat, readInt, readLong, readShort, resetReadIndex, resetWriteIndex, setBoolean, setBytes, setBytes, setBytes, setChar, setDouble, setFloat, setIndex, setReadIndex, setWriteIndex, skipBytes, slice, slice, toByteBuffer, toString, toString, writeBoolean, writeByte, writeBytes, writeBytes, writeBytes, writeBytes, writeBytes, writeBytes, writeBytes, writeDouble, writeFloat, writeInt, writeLong, writeShort
 - 
Methods inherited from class java.lang.Objectclone, finalize, getClass, notify, notifyAll, wait, wait, wait
 - 
Methods inherited from interface org.apache.qpid.protonj2.buffer.ProtonBufferunwrap
 
- 
 
- 
- 
- 
Field Detail- 
DEFAULT_CAPACITYpublic static final int DEFAULT_CAPACITY The default initial capacity used for the underlying byte array.- See Also:
- Constant Field Values
 
 - 
DEFAULT_MAXIMUM_CAPACITYpublic static final int DEFAULT_MAXIMUM_CAPACITY The default maximum capacity that this buffer can grow to.- See Also:
- Constant Field Values
 
 
- 
 - 
Constructor Detail- 
ProtonByteBufferpublic ProtonByteBuffer() Creates a newProtonByteBufferinstance that uses default configuration values for initial capacity and the maximum allowed capacity to which the underlying byte array will grow before errors will be thrown from operations that would expand the storage.
 - 
ProtonByteBufferpublic ProtonByteBuffer(int initialCapacity) Creates a newProtonByteBufferwith the given initial capacity and uses the default value for the maximum capacity restriction.- Parameters:
- initialCapacity- The initial size of the backing byte store.
- Throws:
- java.lang.IllegalArgumentException- if the given value is less than zero.
 
 - 
ProtonByteBufferpublic ProtonByteBuffer(int initialCapacity, int maximumCapacity)Creates a newProtonByteBufferwith the given initial capacity and the given maximum capacity restriction.- Parameters:
- initialCapacity- The initial size of the backing byte store.
- maximumCapacity- The maximum size the backing byte store is allowed to grow.
- Throws:
- java.lang.IllegalArgumentException- if the given value is less than zero or greater than the maximum.
 
 - 
ProtonByteBufferpublic ProtonByteBuffer(byte[] array) Creates a newProtonByteBufferwith the given byte array as the backing store to be used initially. The buffer uses the default value for maximum capacity meaning as the buffer is written to the backing store will eventually be reallocated and no longer wrap the original array. The resulting buffer will have a read index of zero and a write index set to the size of the backing array.- Parameters:
- array- The initial array use use as the backing store for this byte buffer.
 
 - 
ProtonByteBufferprotected ProtonByteBuffer(byte[] array, int maximumCapacity)
 - 
ProtonByteBufferprotected ProtonByteBuffer(byte[] array, int maximumCapacity, int writeIndex)
 
- 
 - 
Method Detail- 
capacitypublic int capacity() - Returns:
- the number of bytes this buffer can currently contain.
 
 - 
capacitypublic ProtonBuffer capacity(int newCapacity) Description copied from interface:ProtonBufferAdjusts the capacity of this buffer. If the new capacity is less than the current capacity, the content of this buffer is truncated. If the new capacity is greater than the current capacity, the buffer is appended with unspecified data whose length is new capacity - current capacity.- Parameters:
- newCapacity- the new maximum capacity value of this buffer.
- Returns:
- this buffer for using in call chaining.
 
 - 
copypublic ProtonBuffer copy(int index, int length) Description copied from interface:ProtonBufferReturns a copy of this buffer's sub-region. Modifying the content of the returned buffer or this buffer does not affect each other at all. This method does not modify the value returned fromProtonBuffer.getReadIndex()orProtonBuffer.getWriteIndex()of this buffer.- Specified by:
- copyin interface- ProtonBuffer
- Specified by:
- copyin class- ProtonAbstractBuffer
- Parameters:
- index- The index in this buffer where the copy should begin
- length- The number of bytes to copy to the new buffer from this one.
- Returns:
- a new ProtonBuffer instance containing the copied bytes.
 
 - 
toByteBufferpublic java.nio.ByteBuffer toByteBuffer(int index, int length)Description copied from interface:ProtonBufferReturns a ByteBuffer that represents the given span of bytes from the readable portion of this buffer.This method should attempt to return a ByteBuffer that shares the backing data store with this buffer however if that is not possible it is permitted that the returned ByteBuffer contain a copy of the readable bytes of this ProtonBuffer. - Specified by:
- toByteBufferin interface- ProtonBuffer
- Specified by:
- toByteBufferin class- ProtonAbstractBuffer
- Parameters:
- index- The starting index in this where the ByteBuffer view should begin.
- length- The number of bytes to include in the ByteBuffer view.
- Returns:
- a ByteBuffer that represents the given view of this buffers readable bytes.
 
 - 
hasArraypublic boolean hasArray() - Returns:
- true if this buffer has a backing byte array that can be accessed.
 
 - 
getArraypublic byte[] getArray() Description copied from interface:ProtonBufferReturns the backing array for this ProtonBuffer instance if there is such an array or throws an exception if this ProtonBuffer implementation has no backing array.Changes to the returned array are visible to other users of this ProtonBuffer. - Returns:
- the backing byte array for this ProtonBuffer.
 
 - 
getArrayOffsetpublic int getArrayOffset() - Returns:
- the offset of the first byte in the backing array belonging to this buffer.
 
 - 
getBytepublic byte getByte(int index) Description copied from interface:ProtonBufferGets a byte from the specified index, this method will not modify the read or write index.- Parameters:
- index- The index into the buffer where the value should be read.
- Returns:
- the value read from the given index.
 
 - 
getShortpublic short getShort(int index) Description copied from interface:ProtonBufferGets a short from the specified index, this method will not modify the read or write index.- Parameters:
- index- The index into the buffer where the value should be read.
- Returns:
- the value read from the given index.
 
 - 
getIntpublic int getInt(int index) Description copied from interface:ProtonBufferGets a int from the specified index, this method will not modify the read or write index.- Parameters:
- index- The index into the buffer where the value should be read.
- Returns:
- the value read from the given index.
 
 - 
getLongpublic long getLong(int index) Description copied from interface:ProtonBufferGets a long from the specified index, this method will not modify the read or write index.- Parameters:
- index- The index into the buffer where the value should be read.
- Returns:
- the value read from the given index.
 
 - 
getBytespublic ProtonBuffer getBytes(int index, ProtonBuffer destination, int destinationIndex, int length) Description copied from interface:ProtonBufferTransfers this buffer's data to the specified destination starting at the specified absoluteindex. This method does not modifyreadIndexorwriteIndexof both the source (i.e.this) and the destination.- Parameters:
- index- The index into the buffer where the value should be read.
- destination- The buffer where the bytes read will be written to
- destinationIndex- The offset into the destination where the write starts
- length- The number of bytes to transfer
- Returns:
- this buffer for chaining
 
 - 
getBytespublic ProtonBuffer getBytes(int index, byte[] destination, int destinationIndex, int length) Description copied from interface:ProtonBufferTransfers this buffer's data to the specified destination starting at the specified absoluteindex. This method does not modify#getReadIndex()or#getWriteIndex()of this buffer.- Parameters:
- index- The index into the buffer where the value should be read.
- destination- The buffer where the bytes read will be written to
- destinationIndex- the offset into the destination to begin writing the bytes.
- length- the number of bytes to transfer from this buffer to the target buffer.
- Returns:
- this buffer for chaining
 
 - 
getBytespublic ProtonBuffer getBytes(int index, java.nio.ByteBuffer destination) Description copied from interface:ProtonBufferTransfers this buffer's data to the specified destination starting at the specified absoluteindexuntil the destination's position reaches its limit. This method does not modify#getReadIndex()or#getWriteIndex()of this buffer while the destination'spositionwill be increased.- Parameters:
- index- The index into the buffer where the value should be read.
- destination- The buffer where the bytes read will be written to
- Returns:
- this buffer for chaining
 
 - 
setBytepublic ProtonBuffer setByte(int index, int value) Description copied from interface:ProtonBufferSets the byte value at the given write index in this buffer's backing data store.- Parameters:
- index- The index to start the write from.
- value- The value to write at the given index.
- Returns:
- a reference to this ProtonBuffer for chaining.
 
 - 
setShortpublic ProtonBuffer setShort(int index, int value) Description copied from interface:ProtonBufferSets the short value at the given write index in this buffer's backing data store.- Parameters:
- index- The index to start the write from.
- value- The value to write at the given index.
- Returns:
- a reference to this ProtonBuffer for chaining.
 
 - 
setIntpublic ProtonBuffer setInt(int index, int value) Description copied from interface:ProtonBufferSets the int value at the given write index in this buffer's backing data store.- Parameters:
- index- The index to start the write from.
- value- The value to write at the given index.
- Returns:
- a reference to this ProtonBuffer for chaining.
 
 - 
setLongpublic ProtonBuffer setLong(int index, long value) Description copied from interface:ProtonBufferSets the long value at the given write index in this buffer's backing data store.- Parameters:
- index- The index to start the write from.
- value- The value to write at the given index.
- Returns:
- a reference to this ProtonBuffer for chaining.
 
 - 
setBytespublic ProtonBuffer setBytes(int index, ProtonBuffer source, int sourceIndex, int length) Description copied from interface:ProtonBufferTransfers the specified source buffer's data to this buffer starting at the specified absoluteindex. This method does not modifyreadIndexorwriteIndexof both the source (i.e.this) and the destination.- Parameters:
- index- The index in this buffer where the write operation starts.
- source- The source buffer from which the bytes are read.
- sourceIndex- The offset into the source where the set begins.
- length- The number of bytes to transfer
- Returns:
- this buffer for chaining
 
 - 
setBytespublic ProtonBuffer setBytes(int index, byte[] source, int sourceIndex, int length) Description copied from interface:ProtonBufferTransfers the specified source array's data to this buffer starting at the specified absoluteindex. This method does not modifyreadIndexorwriteIndexof this buffer.- Parameters:
- index- The index in this buffer where the write operation starts.
- source- The source buffer from which the bytes are read.
- sourceIndex- The offset into the source where the set begins.
- length- The number of bytes to transfer
- Returns:
- this buffer for chaining
 
 - 
setBytespublic ProtonBuffer setBytes(int index, java.nio.ByteBuffer src) Description copied from interface:ProtonBufferTransfers the specified source buffer's data to this buffer starting at the specified absoluteindexuntil the source buffer's position reaches its limit. This method does not modifyreadIndexorwriteIndexof this buffer.- Parameters:
- index- The index in this buffer where the write operation starts.
- src- The source buffer from which the bytes are read.
- Returns:
- this buffer for chaining
 
 
- 
 
-