Package com.tangosol.io.nio
Class BinaryMap.Block
java.lang.Object
com.tangosol.util.Base
com.tangosol.io.nio.BinaryMap.Block
- Enclosing class:
- BinaryMap
A Block is the unit of storage within a Buffer. There are free blocks
 and Entry blocks (that store key/value pairs).
- 
Nested Class SummaryNested classes/interfaces inherited from class com.tangosol.util.BaseBase.LoggingWriter
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final intState of a block that holds an Entry object's data.static final intState of a block that is available for use.static final intMinimum size of an Entry block.static final intMinimum size of a free block.static final intMinimum size of a block to split off a free block.static final intInitial state, also state of an allocated block that has not been linked.static final intOffset of the key's hash within an Entry block.static final intOffset of the key data within an Entry block.static final intOffset (not counting key length) of the value data within an Entry block.
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidallocate(int cb) Allocate this free block (or at least a specified number of bytes of this block) as an Entry block.voidclear()Zero the block.voidZero the value portion of the block.voidclose()Close the Block object, flushing any pending changes, resetting its contents and recycling the object.voiddiscard()Recycle the Block object, discarding any changes, resetting its contents and recycling the object.protected booleanDecrement the use count for this block and check if it is now zero.voidflush()Close the Block object by resetting its contents and recycling the object.voidfree()Free this Entry block.intGet the size of the fill in the block.getKey()Get the Entry key in the block, lazy loading it if necessary.intGet the hash code for the Entry block.intGet the length of the Entry key in the block.intDetermine the length of the block.intDetermine the offset of the next Block in the Buffer.intDetermine the offset of the next Block in the linked list.intDetermine the offset of this Block in the Buffer.intDetermine the offset of the previous Block in the Buffer.intDetermine the offset of the previous Block in the linked list.intDetermine the "free block size code" for a block of this size.intgetType()Determine the current Block type.getValue()Get the Entry value in the block, lazy loading it if necessary.intGet the length of the Entry value in the block.voidinit(int of) Configure the Block object to point to a specific offset within the Buffer.booleanisEntry()Determine if the Block is marked as an Entry.booleanisFree()Determine if the Block is marked as free.intlength()Determine the length of the block.voidlink()Link this block (either an Entry or free block) into the appropriate data structures (either the hash bucket or the free list.)voidmerge()Merge a free block with any free blocks that it borders.voidRead a block's header data from the Buffer.voidreadKey()Read the "key" portion of an Entry block.voidRead the "value" portion of an Entry block.voidreset()Reset the Block object so that it doesn't point into the Buffer.voidUpdate the Entry key in the block.voidsetNextBlockOffset(int ofBlock) Specify the offset of the next Block in the Buffer.voidsetNextNodeOffset(int ofBlock) Specify the offset of the next Block in the linked list.voidsetOffset(int ofBlock) Specify the offset of this Block in the Buffer.voidsetPrevBlockOffset(int ofBlock) Specify the offset of the previous Block in the Buffer.voidsetPrevNodeOffset(int ofBlock) Specify the offset of the previous Block in the linked list.voidsetType(int nType) Set the Block type.voidUpdate the Entry value in the block.voidsplit(int cbRetain) If possible, chop a free block into two free blocks, or chop the end of an Entry block to make a free block.voidunlink()Unlink this block (either an Entry or free block) from the appropriate data structures (either the hash bucket or the free list.)protected voiduse()Increment the use count for this block.voidWrite the block's data to the Buffer.voidwriteKey()Write the "key" portion of an Entry block, including the key hash.voidWrite the "value" portion of an Entry block.Methods inherited from class com.tangosol.util.Baseazzert, azzert, azzert, azzertFailed, breakLines, breakLines, capitalize, checkNotEmpty, checkNotNull, checkRange, computeSafeWaitTime, decimalValue, dup, dup, ensureBigDecimal, ensureClassLoader, ensureRuntimeException, ensureRuntimeException, equals, equalsDeep, err, err, err, err, err, escape, formatDateTime, getCallerStackFrame, getCommonMonitor, getCommonMonitor, getCommonMonitor, getContextClassLoader, getContextClassLoader, getDeepMessage, getErr, getLastSafeTimeMillis, getLog, getMaxDecDigits, getMaxHexDigits, getOriginalException, getOut, getProcessRandom, getRandom, getRandomBinary, getRandomBinary, getRandomString, getSafeTimeMillis, getStackFrame, getStackFrames, getStackTrace, getStackTrace, getStackTrace, getThreadFactory, getTimeZone, getUpTimeMillis, hashCode, hexValue, indentString, indentString, isDecimal, isHex, isLogEcho, isOctal, log, log, log, log, log, makeInteger, makeLong, makeThread, mergeArray, mergeBooleanArray, mergeByteArray, mergeCharArray, mergeDoubleArray, mergeFloatArray, mergeIntArray, mergeLongArray, mod, mod, octalValue, out, out, out, out, out, pad, parseBandwidth, parseBandwidth, parseDelimitedString, parseHex, parseHex, parseMemorySize, parseMemorySize, parsePercentage, parseTime, parseTime, parseTimeNanos, parseTimeNanos, printStackTrace, randomize, randomize, randomize, randomize, read, read, read, read, read, read, read, replace, setErr, setLog, setLogEcho, setOut, sleep, toBandwidthString, toBandwidthString, toCharEscape, toCrc, toCrc, toCrc, toCrc, toCrc, toDecString, toDelimitedString, toDelimitedString, toDelimitedString, toDelimitedString, toHex, toHex, toHexDump, toHexEscape, toHexEscape, toHexEscape, toHexEscape, toHexString, toMemorySizeString, toMemorySizeString, toQuotedCharEscape, toQuotedStringEscape, toSqlString, toString, toString, toStringEscape, toUnicodeEscape, trace, trace, trace, trace, trace, trace, trace, trace, trace, truncateString, truncateString, wait
- 
Field Details- 
NONEpublic static final int NONEInitial state, also state of an allocated block that has not been linked.- See Also:
 
- 
FREEpublic static final int FREEState of a block that is available for use.- See Also:
 
- 
ENTRYpublic static final int ENTRYState of a block that holds an Entry object's data.- See Also:
 
- 
OFFSET_HASHpublic static final int OFFSET_HASHOffset of the key's hash within an Entry block.- See Also:
 
- 
OFFSET_KEYpublic static final int OFFSET_KEYOffset of the key data within an Entry block.- See Also:
 
- 
OFFSET_VALUEpublic static final int OFFSET_VALUEOffset (not counting key length) of the value data within an Entry block.- See Also:
 
- 
MIN_SPLITpublic static final int MIN_SPLITMinimum size of a block to split off a free block.- See Also:
 
- 
MIN_FREEpublic static final int MIN_FREEMinimum size of a free block.- See Also:
 
- 
MIN_ENTRYpublic static final int MIN_ENTRYMinimum size of an Entry block.- See Also:
 
 
- 
- 
Constructor Details- 
Blockpublic Block()Construct a Block.
 
- 
- 
Method Details- 
initpublic void init(int of) Configure the Block object to point to a specific offset within the Buffer.- Parameters:
- of- the offset of the Block within the Buffer
 
- 
useprotected void use()Increment the use count for this block.
- 
finishUseprotected boolean finishUse()Decrement the use count for this block and check if it is now zero.
- 
resetpublic void reset()Reset the Block object so that it doesn't point into the Buffer. Block objects can be re-used to reduce allocations by calling the close() method.
- 
flushpublic void flush()Close the Block object by resetting its contents and recycling the object.
- 
closepublic void close()Close the Block object, flushing any pending changes, resetting its contents and recycling the object.
- 
discardpublic void discard()Recycle the Block object, discarding any changes, resetting its contents and recycling the object.
- 
clearpublic void clear()Zero the block.
- 
clearValuepublic void clearValue()Zero the value portion of the block.
- 
getTypepublic int getType()Determine the current Block type.- Returns:
- one of {NONE, FREE, ENTRY}
 
- 
setTypepublic void setType(int nType) Set the Block type.- Parameters:
- nType- the new Block type
 
- 
isFreepublic boolean isFree()Determine if the Block is marked as free.- Returns:
- true if and only if the type is FREE
 
- 
isEntrypublic boolean isEntry()Determine if the Block is marked as an Entry.- Returns:
- true if and only if the type is ENTRY
 
- 
getOffsetpublic int getOffset()Determine the offset of this Block in the Buffer.- Returns:
- the offset of this Block in the Buffer, or NIL if this Block has not been initialized
 
- 
setOffsetpublic void setOffset(int ofBlock) Specify the offset of this Block in the Buffer.- Parameters:
- ofBlock- the offset of this Block
 
- 
getLengthpublic int getLength()Determine the length of the block.- Returns:
- the length, in bytes, of this block
 
- 
lengthpublic int length()Determine the length of the block.- Returns:
- the length, in bytes, of this block
 
- 
getSizeCodepublic int getSizeCode()Determine the "free block size code" for a block of this size.- Returns:
- the size code for this block
 
- 
getNextBlockOffsetpublic int getNextBlockOffset()Determine the offset of the next Block in the Buffer.- Returns:
- the offset of the next Block in the Buffer, or NIL if this Block is the last in the Buffer
 
- 
setNextBlockOffsetpublic void setNextBlockOffset(int ofBlock) Specify the offset of the next Block in the Buffer.- Parameters:
- ofBlock- the offset of the next contiguous Block
 
- 
getPrevBlockOffsetpublic int getPrevBlockOffset()Determine the offset of the previous Block in the Buffer.- Returns:
- the offset of the previous Block in the Buffer, or NIL if this Block is the first in the Buffer
 
- 
setPrevBlockOffsetpublic void setPrevBlockOffset(int ofBlock) Specify the offset of the previous Block in the Buffer.- Parameters:
- ofBlock- the offset of the previous contiguous Block
 
- 
getNextNodeOffsetpublic int getNextNodeOffset()Determine the offset of the next Block in the linked list.- Returns:
- the offset of the next Block in the linked list, or NIL if this Block is the last in the linked list
 
- 
setNextNodeOffsetpublic void setNextNodeOffset(int ofBlock) Specify the offset of the next Block in the linked list.- Parameters:
- ofBlock- the offset of the next Block in the linked list of Blocks
 
- 
getPrevNodeOffsetpublic int getPrevNodeOffset()Determine the offset of the previous Block in the linked list.- Returns:
- the offset of the previous Block in the linked list, or NIL if this Block is the first in the linked list of Blocks
 
- 
setPrevNodeOffsetpublic void setPrevNodeOffset(int ofBlock) Specify the offset of the previous Block in the linked list.- Parameters:
- ofBlock- the offset of the previous Block in the linked list of blocks
 
- 
getKeyHashpublic int getKeyHash()Get the hash code for the Entry block.- Returns:
- the hash code for the Entry block
 
- 
getKeyLengthpublic int getKeyLength()Get the length of the Entry key in the block.- Returns:
- the length, in bytes, of the key
 
- 
getKeyGet the Entry key in the block, lazy loading it if necessary.- Returns:
- the Entry key
 
- 
setKeyUpdate the Entry key in the block. The write is deferred.- Parameters:
- bin- the Entry key
 
- 
getValueLengthpublic int getValueLength()Get the length of the Entry value in the block.- Returns:
- the length, in bytes, of the value
 
- 
getValueGet the Entry value in the block, lazy loading it if necessary.- Returns:
- the Entry value
 
- 
setValueUpdate the Entry value in the block. The write is deferred.- Parameters:
- bin- the Entry value
 
- 
getFillLengthpublic int getFillLength()Get the size of the fill in the block.- Returns:
- the length, in bytes, of the fill
 
- 
readHeaderpublic void readHeader()Read a block's header data from the Buffer. Also reads key hash, key length and value length.
- 
writeHeaderpublic void writeHeader()Write the block's data to the Buffer.
- 
readKeypublic void readKey()Read the "key" portion of an Entry block.
- 
writeKeypublic void writeKey()Write the "key" portion of an Entry block, including the key hash.
- 
readValuepublic void readValue()Read the "value" portion of an Entry block. Note that if the length of the key is modified, the value must be read first or it will be unreadable.
- 
writeValuepublic void writeValue()Write the "value" portion of an Entry block.
- 
linkpublic void link()Link this block (either an Entry or free block) into the appropriate data structures (either the hash bucket or the free list.)
- 
unlinkpublic void unlink()Unlink this block (either an Entry or free block) from the appropriate data structures (either the hash bucket or the free list.)
- 
splitpublic void split(int cbRetain) If possible, chop a free block into two free blocks, or chop the end of an Entry block to make a free block.- Parameters:
- cbRetain- the number of bytes to allocate to the first of the two free blocks
 
- 
mergepublic void merge()Merge a free block with any free blocks that it borders.
- 
allocatepublic void allocate(int cb) Allocate this free block (or at least a specified number of bytes of this block) as an Entry block. Note that the block is an Entry in an unlinked state at the termination of this method.- Parameters:
- cb- the minimum number of bytes required for the Entry block
 
- 
freepublic void free()Free this Entry block. Note that this has the effect of closing the block.
 
-