Class ProtonNettyByteBufferAllocator
- java.lang.Object
- 
- org.apache.qpid.protonj2.buffer.ProtonNettyByteBufferAllocator
 
- 
- All Implemented Interfaces:
- ProtonBufferAllocator
 
 public class ProtonNettyByteBufferAllocator extends java.lang.Object implements ProtonBufferAllocator A defaultProtonBufferAllocatorthat creates wrapped NettyByteBufbuffers. Output buffers are created using a Netty ByteBuf backedProtonBufferwhile the other methods may choose to use simpleProtonByteBufferobjects to reduce the number of intermediate allocations from wrapping one buffer type with another.
- 
- 
Field SummaryFields Modifier and Type Field Description static ProtonNettyByteBufferAllocatorDEFAULTA default instance of theProtonNettyByteBufferAllocatorthat uses default configurations.
 - 
Constructor SummaryConstructors Constructor Description ProtonNettyByteBufferAllocator()
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description ProtonByteBufferallocate()Create a new ProtonBuffer instance with default initial capacity.ProtonByteBufferallocate(int initialCapacity)Create a new ProtonBuffer instance with the given initial capacity and the maximum capacity should be that of the underlying buffer implementations limit.ProtonByteBufferallocate(int initialCapacity, int maximumCapacity)Create a new ProtonBuffer instance with the given initial capacity and the maximum capacity should that of the value specified by the caller.ProtonBufferoutputBuffer(int initialCapacity)Create a new output ProtonBuffer instance with the given initial capacity and the maximum capacity should be that of the underlying buffer implementations limit.ProtonBufferoutputBuffer(int initialCapacity, int maximumCapacity)Create a new output ProtonBuffer instance with the given initial capacity and the maximum capacity should that of the value specified by the caller.ProtonBufferwrap(byte[] array)Create a new ProtonBuffer that wraps the given byte array.ProtonBufferwrap(byte[] array, int offset, int length)Create a new ProtonBuffer that wraps the given byte array using the provided offset and length values to confine the view of that array.ProtonBufferwrap(java.nio.ByteBuffer buffer)Create a new ProtonBuffer that wraps the given ByteBuffer.
 
- 
- 
- 
Field Detail- 
DEFAULTpublic static final ProtonNettyByteBufferAllocator DEFAULT A default instance of theProtonNettyByteBufferAllocatorthat uses default configurations.
 
- 
 - 
Method Detail- 
outputBufferpublic ProtonBuffer outputBuffer(int initialCapacity) Description copied from interface:ProtonBufferAllocatorCreate a new output ProtonBuffer instance with the given initial capacity and the maximum capacity should be that of the underlying buffer implementations limit. The buffer implementation should support growing the buffer on an as needed basis to allow writes without the user needing to code extra capacity and buffer reallocation checks.The returned buffer will be used for frame output from the Proton engine and can be a pooled buffer which the IO handler will then need to release once the buffer has been written. - Specified by:
- outputBufferin interface- ProtonBufferAllocator
- Parameters:
- initialCapacity- The initial capacity to use when creating the new ProtonBuffer.
- Returns:
- a new ProtonBuffer instance with the given initial capacity.
 
 - 
outputBufferpublic ProtonBuffer outputBuffer(int initialCapacity, int maximumCapacity) Description copied from interface:ProtonBufferAllocatorCreate a new output ProtonBuffer instance with the given initial capacity and the maximum capacity should that of the value specified by the caller.The returned buffer will be used for frame output from the Proton engine and can be a pooled buffer which the IO handler will then need to release once the buffer has been written. - Specified by:
- outputBufferin interface- ProtonBufferAllocator
- Parameters:
- initialCapacity- The initial capacity to use when creating the new ProtonBuffer.
- maximumCapacity- The largest amount of bytes the new ProtonBuffer is allowed to grow to.
- Returns:
- a new ProtonBuffer instance with the given initial capacity.
 
 - 
allocatepublic ProtonByteBuffer allocate() Description copied from interface:ProtonBufferAllocatorCreate a new ProtonBuffer instance with default initial capacity. The buffer implementation should support growing the buffer on an as needed basis to allow writes without the user needing to code extra capacity and buffer reallocation checks. It is not recommended that these buffers be backed by a pooled resource as there is no defined release point within the buffer API and if used by an AMQP engine they could be lost as buffers are copied or aggregated together.- Specified by:
- allocatein interface- ProtonBufferAllocator
- Returns:
- a new ProtonBuffer instance with default initial capacity.
 
 - 
allocatepublic ProtonByteBuffer allocate(int initialCapacity) Description copied from interface:ProtonBufferAllocatorCreate a new ProtonBuffer instance with the given initial capacity and the maximum capacity should be that of the underlying buffer implementations limit. It is not recommended that these buffers be backed by a pooled resource as there is no defined release point within the buffer API and if used by an AMQP engine they could be lost as buffers are copied or aggregated together.- Specified by:
- allocatein interface- ProtonBufferAllocator
- Parameters:
- initialCapacity- The initial capacity to use when creating the new ProtonBuffer.
- Returns:
- a new ProtonBuffer instance with the given initial capacity.
 
 - 
allocatepublic ProtonByteBuffer allocate(int initialCapacity, int maximumCapacity) Description copied from interface:ProtonBufferAllocatorCreate a new ProtonBuffer instance with the given initial capacity and the maximum capacity should that of the value specified by the caller. It is not recommended that these buffers be backed by a pooled resource as there is no defined release point within the buffer API and if used by an AMQP engine they could be lost as buffers are copied or aggregated together.- Specified by:
- allocatein interface- ProtonBufferAllocator
- Parameters:
- initialCapacity- The initial capacity to use when creating the new ProtonBuffer.
- maximumCapacity- The largest amount of bytes the new ProtonBuffer is allowed to grow to.
- Returns:
- a new ProtonBuffer instance with the given initial capacity.
 
 - 
wrappublic ProtonBuffer wrap(byte[] array) Description copied from interface:ProtonBufferAllocatorCreate a new ProtonBuffer that wraps the given byte array.The capacity and maximum capacity for the resulting ProtonBuffer should equal to the length of the wrapped array and the returned array offset is zero. - Specified by:
- wrapin interface- ProtonBufferAllocator
- Parameters:
- array- the byte array to wrap.
- Returns:
- a new ProtonBuffer that wraps the given array.
 
 - 
wrappublic ProtonBuffer wrap(byte[] array, int offset, int length) Description copied from interface:ProtonBufferAllocatorCreate a new ProtonBuffer that wraps the given byte array using the provided offset and length values to confine the view of that array. The maximum capacity of the buffer should be that of the length of the wrapped array.The capacity and maximum capacity for the resulting ProtonBuffer should equal to the length parameter provided and the returned buffer offset will be zero. - Specified by:
- wrapin interface- ProtonBufferAllocator
- Parameters:
- array- the byte array to wrap.
- offset- the offset into the array where the view begins.
- length- the number of bytes in the array to expose
- Returns:
- a new ProtonBuffer that wraps the given array.
 
 - 
wrappublic ProtonBuffer wrap(java.nio.ByteBuffer buffer) Description copied from interface:ProtonBufferAllocatorCreate a new ProtonBuffer that wraps the given ByteBuffer. The maximum capacity of the returned buffer should be same as the remaining bytes within the wrappedByteBuffer.The capacity and maximum capacity of the returned ProtonBuffer will be the same as that of the underlying ByteBuffer. The ProtonBuffer will return true from the ProtonBuffer.hasArray()method only when the wrapped ByteBuffer reports that it is backed by an array.- Specified by:
- wrapin interface- ProtonBufferAllocator
- Parameters:
- buffer- the- ByteBufferto wrap.
- Returns:
- a new ProtonBuffer that wraps the given ByteBuffer.
 
 
- 
 
-