@ManagedObject public class ArrayByteBufferPool extends Object
A ByteBuffer pool where ByteBuffers are held in queues that are held in array elements.
Given a capacity factor
of 1024, the first array element holds a queue of ByteBuffers
each of capacity 1024, the second array element holds a queue of ByteBuffers each of capacity
2048, and so on.
ByteBufferPool.Bucket, ByteBufferPool.Lease
Constructor and Description |
---|
ArrayByteBufferPool()
Creates a new ArrayByteBufferPool with a default configuration.
|
ArrayByteBufferPool(int minCapacity,
int factor,
int maxCapacity)
Creates a new ArrayByteBufferPool with the given configuration.
|
ArrayByteBufferPool(int minCapacity,
int factor,
int maxCapacity,
int maxQueueLength)
Creates a new ArrayByteBufferPool with the given configuration.
|
ArrayByteBufferPool(int minCapacity,
int factor,
int maxCapacity,
int maxQueueLength,
long maxHeapMemory,
long maxDirectMemory)
Creates a new ArrayByteBufferPool with the given configuration.
|
Modifier and Type | Method and Description |
---|---|
ByteBuffer |
acquire(int size,
boolean direct)
Requests a
ByteBuffer of the given size. |
void |
clear() |
long |
getDirectByteBufferCount() |
long |
getDirectMemory() |
long |
getHeapByteBufferCount() |
long |
getHeapMemory() |
long |
getMemory(boolean direct) |
void |
release(ByteBuffer buffer)
Returns a
ByteBuffer , usually obtained with ByteBufferPool.acquire(int, boolean)
(but not necessarily), making it available for recycling and reuse. |
equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
newByteBuffer
public ArrayByteBufferPool()
public ArrayByteBufferPool(int minCapacity, int factor, int maxCapacity)
minCapacity
- the minimum ByteBuffer capacityfactor
- the capacity factormaxCapacity
- the maximum ByteBuffer capacitypublic ArrayByteBufferPool(int minCapacity, int factor, int maxCapacity, int maxQueueLength)
minCapacity
- the minimum ByteBuffer capacityfactor
- the capacity factormaxCapacity
- the maximum ByteBuffer capacitymaxQueueLength
- the maximum ByteBuffer queue lengthpublic ArrayByteBufferPool(int minCapacity, int factor, int maxCapacity, int maxQueueLength, long maxHeapMemory, long maxDirectMemory)
minCapacity
- the minimum ByteBuffer capacityfactor
- the capacity factormaxCapacity
- the maximum ByteBuffer capacitymaxQueueLength
- the maximum ByteBuffer queue lengthmaxHeapMemory
- the max heap memory in bytesmaxDirectMemory
- the max direct memory in bytespublic ByteBuffer acquire(int size, boolean direct)
ByteBufferPool
Requests a ByteBuffer
of the given size.
The returned buffer may have a bigger capacity than the size being requested but it will have the limit set to the given size.
size
- the size of the bufferdirect
- whether the buffer must be direct or notByteBufferPool.release(ByteBuffer)
public void release(ByteBuffer buffer)
ByteBufferPool
Returns a ByteBuffer
, usually obtained with ByteBufferPool.acquire(int, boolean)
(but not necessarily), making it available for recycling and reuse.
buffer
- the buffer to returnByteBufferPool.acquire(int, boolean)
public void clear()
@ManagedAttribute(value="The number of pooled direct ByteBuffers") public long getDirectByteBufferCount()
@ManagedAttribute(value="The number of pooled heap ByteBuffers") public long getHeapByteBufferCount()
@ManagedAttribute(value="The bytes retained by direct ByteBuffers") public long getDirectMemory()
@ManagedAttribute(value="The bytes retained by heap ByteBuffers") public long getHeapMemory()
public long getMemory(boolean direct)
Copyright © 2010 - 2020 Adobe. All Rights Reserved