Package org.apache.hadoop.hbase.io
Interface HeapSize
- All Known Subinterfaces:
Cacheable,Cell,ExtendedCell,FirstLevelBlockCache,HFileIndexBlockEncoder.EncodedSeeker,RawCell,RegionSize,RegionSizeStore,SizedExtendedCellScanner
- All Known Implementing Classes:
Append,BlockCacheKey,BucketCache,BufferedDataBlockEncoder.OffheapDecodedExtendedCell,BufferedDataBlockEncoder.OnheapDecodedCell,ByteBufferChunkKeyValue,ByteBufferExtendedCell,ByteBufferKeyOnlyKeyValue,ByteBufferKeyValue,CombinedBlockCache,Compression.HFileDecompressionContext,Delete,EntryBuffers.RegionEntryBuffer,ExclusiveMemHFileBlock,HFileBlock,HFileBlockIndex.BlockIndexReader,HFileBlockIndex.ByteArrayKeyBlockIndexReader,HFileBlockIndex.CellBasedKeyBlockIndexReader,HFileBlockIndex.CellBasedKeyBlockIndexReaderV2,HFileContext,HMobStore,HRegion,HStore,InclusiveCombinedBlockCache,Increment,IndexOnlyLruBlockCache,IndividualBytesFieldCell,KeyOnlyFilter.KeyOnlyByteBufferExtendedCell,KeyOnlyFilter.KeyOnlyCell,KeyValue,KeyValue.KeyOnlyKeyValue,LruAdaptiveBlockCache,LruBlockCache,LruCachedBlock,LruCachedBlockQueue,MapReduceExtendedCell,Mutation,NoOpIndexBlockEncoder.NoOpEncodedSeeker,NoOpRegionSizeStore,NoTagByteBufferChunkKeyValue,NoTagsByteBufferKeyValue,NoTagsKeyValue,PrivateCellUtil.EmptyByteBufferExtendedCell,PrivateCellUtil.EmptyCell,PrivateCellUtil.FirstOnRowByteBufferExtendedCell,PrivateCellUtil.FirstOnRowCell,PrivateCellUtil.FirstOnRowColByteBufferExtendedCell,PrivateCellUtil.FirstOnRowColCell,PrivateCellUtil.FirstOnRowColTSByteBufferExtendedCell,PrivateCellUtil.FirstOnRowColTSCell,PrivateCellUtil.FirstOnRowDeleteFamilyCell,PrivateCellUtil.LastOnRowByteBufferExtendedCell,PrivateCellUtil.LastOnRowCell,PrivateCellUtil.LastOnRowColByteBufferExtendedCell,PrivateCellUtil.LastOnRowColCell,PrivateCellUtil.TagRewriteByteBufferExtendedCell,PrivateCellUtil.TagRewriteCell,PrivateCellUtil.ValueAndTagRewriteByteBufferExtendedCell,PrivateCellUtil.ValueAndTagRewriteCell,Put,RegionSizeImpl,RegionSizeStoreImpl,SharedMemHFileBlock,SizeCachedByteBufferKeyValue,SizeCachedKeyValue,SizeCachedNoTagsByteBufferKeyValue,SizeCachedNoTagsKeyValue,StoreContext,TinyLfuBlockCache,WALEdit,ZstdHFileDecompressionContext
Implementations can be asked for an estimate of their size in bytes.
Useful for sizing caches. Its a given that implementation approximations do not account for 32 vs 64 bit nor for different VM implementations.
An Object's size is determined by the non-static data members in it, as well as the fixed
Object overhead.
For example:
public class SampleObject implements HeapSize {
int[] numbers;
int x;
}
-
Method Summary
Modifier and TypeMethodDescriptionlongheapSize()Return the approximate 'exclusive deep size' of implementing object.
-
Method Details
-
heapSize
long heapSize()Return the approximate 'exclusive deep size' of implementing object. Includes count of payload and hosting object sizings.
-