Package org.infinispan.container.offheap
Class UnpooledOffHeapMemoryAllocator
java.lang.Object
org.infinispan.container.offheap.UnpooledOffHeapMemoryAllocator
- All Implemented Interfaces:
- OffHeapMemoryAllocator
Memory allocator that just allocates memory directly using 
Unsafe.- Since:
- 9.0
- Author:
- wburns
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionlongallocate(long memoryLength) Allocates a new chunk of memory sized to the given length.voiddeallocate(long memoryAddress, long size) Deallocates the memory at the given address assuming a given size.static longestimateSizeOverhead(long size) Tries to estimate overhead of the allocation by first adding 8 to account for underlying allocator housekeeping and then rounds up to nearest power of 16 to account for 16 byte alignment.longstatic longoffHeapEntrySize(boolean evictionEnabled, boolean writeMetadataSize, int keySize, int valueSize) static longoffHeapEntrySize(boolean evictionEnabled, boolean writeMetadataSize, int keySize, int valueSize, int metadataSize, int internalMetadataSize) It returns the off-heap size of an entry without alignment.
- 
Constructor Details- 
UnpooledOffHeapMemoryAllocatorpublic UnpooledOffHeapMemoryAllocator()
 
- 
- 
Method Details- 
allocatepublic long allocate(long memoryLength) Description copied from interface:OffHeapMemoryAllocatorAllocates a new chunk of memory sized to the given length.- Specified by:
- allocatein interface- OffHeapMemoryAllocator
- Parameters:
- memoryLength- the size of memory to allocate
- Returns:
- the memory address where the memory resides
 
- 
deallocatepublic void deallocate(long memoryAddress, long size) Description copied from interface:OffHeapMemoryAllocatorDeallocates the memory at the given address assuming a given size. This size is the size that was provided to allocate.- Specified by:
- deallocatein interface- OffHeapMemoryAllocator
- Parameters:
- memoryAddress- the address to deallocate from
- size- the total size
 
- 
getAllocatedAmountpublic long getAllocatedAmount()- Specified by:
- getAllocatedAmountin interface- OffHeapMemoryAllocator
 
- 
estimateSizeOverheadpublic static long estimateSizeOverhead(long size) Tries to estimate overhead of the allocation by first adding 8 to account for underlying allocator housekeeping and then rounds up to nearest power of 16 to account for 16 byte alignment.- Parameters:
- size- the desired size of the allocation
- Returns:
- the resulting size taking into account various overheads
 
- 
offHeapEntrySizepublic static long offHeapEntrySize(boolean evictionEnabled, boolean writeMetadataSize, int keySize, int valueSize) 
- 
offHeapEntrySizepublic static long offHeapEntrySize(boolean evictionEnabled, boolean writeMetadataSize, int keySize, int valueSize, int metadataSize, int internalMetadataSize) It returns the off-heap size of an entry without alignment.If alignment is required, use estimateSizeOverhead(offHeapEntrySize(...)). SeeestimateSizeOverhead(long),- Parameters:
- evictionEnabled- Set to- trueif eviction is enabled.
- writeMetadataSize- Set to- trueif the- Metadatahas versioning or it is a custom implementation.
- keySize- The key size.
- valueSize- The value size.
- metadataSize- The- Metadatasize. If- writeMetadataSizeis false, this parameter must include the size of mortal/transient entries (2 or 4 longs).
- internalMetadataSize- The- PrivateMetadatasize.
- Returns:
- The off-heap entry size without alignment!
 
 
-