Class MemByteHolder
java.lang.Object
org.apache.derby.impl.store.raw.data.MemByteHolder
- All Implemented Interfaces:
ByteHolder
A ByteHolder that stores all its bytes in memory.
-
Field Summary
FieldsModifier and TypeFieldDescription(package private) int(package private) Vector<byte[]> (package private) byte[](package private) int(package private) int(package private) int(package private) int(package private) int(package private) boolean -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionintReturn the number of bytes that can be read from this ByteHolder without blocking on an IO.voidclear()Clear the bytes from the ByteHolder and place it in writing mode.Return a byte holder matching existing type and size of current ByteHolder, but don't bother to fill the bytes.private StringdumpBuf(int bufVEleAt) Create a string representation of an internal buffer of bytes.protected booleanGet the next buffer for reading bytes.protected voidGet the next buffer for writing bytes.protected voidDo sanity checking when getting the next write bufferprotected voidInitialize a buffer for writingintReturn the number of bytes that have been saved to this byte holder.intread()Read a byte from this ByteHolder.intread(byte[] b, int off, int len) Read up to 'len' bytes from this ByteHolder and store them in an array at offset 'off'.intread(byte[] b, int off, OutputStream out, int len) intread(OutputStream out, int len) Read from the ByteHolder.intshift the remaining unread bytes to the beginning of the byte holderlongskip(long count) Skip over the specified number of bytes in a ByteHolder.voidPlace a ByteHolder in reading mode.toString()Produce a string describing the state of this ByteHolder.voidwrite(byte[] data, int offset, int len) Write len bytes of data starting at 'offset' to this ByteHolder.voidwrite(int b) Write a byte to this ByteHolder.longwrite(InputStream is, long count) Write up to count bytes from an input stream to this ByteHolder.booleanReturn true if this is in writing mode.
-
Field Details
-
bufSize
int bufSize -
writing
boolean writing -
bufV
Vector<byte[]> bufV -
curBufVEleAt
int curBufVEleAt -
curBuf
byte[] curBuf -
curBufPos
int curBufPos -
curBufDataBytes
int curBufDataBytes -
lastBufVEleAt
int lastBufVEleAt -
lastBufDataBytes
int lastBufDataBytes
-
-
Constructor Details
-
MemByteHolder
public MemByteHolder(int bufSize) Create a new MemByteHolder. Store bytes as a list of buffers of size 'bufSize'.
-
-
Method Details
-
write
Description copied from interface:ByteHolderWrite a byte to this ByteHolder.The ByteHolder must be in writing mode to call this.
- Specified by:
writein interfaceByteHolder- Throws:
IOException- Thrown on error- See Also:
-
write
Description copied from interface:ByteHolderWrite len bytes of data starting at 'offset' to this ByteHolder.The ByteHolder must be in writing mode to call this.
- Specified by:
writein interfaceByteHolder- Throws:
IOException- Thrown on error- See Also:
-
write
Description copied from interface:ByteHolderWrite up to count bytes from an input stream to this ByteHolder. This may write fewer bytes if it encounters an end of file on the input stream.- Specified by:
writein interfaceByteHolder- Returns:
- the number of bytes written.
- Throws:
IOException- Thrown on error- See Also:
-
clear
Description copied from interface:ByteHolderClear the bytes from the ByteHolder and place it in writing mode. This may not free the memory the ByteHolder uses to store data.- Specified by:
clearin interfaceByteHolder- Throws:
IOException- Thrown on error- See Also:
-
startReading
Description copied from interface:ByteHolderPlace a ByteHolder in reading mode. After this call, reads scan bytes sequentially in the order they were written to the ByteHolder starting from the first byte. When the ByteHolder is already in readmode this simply arranges for reads to start at the beginning of the sequence of saved bytes.- Specified by:
startReadingin interfaceByteHolder- Throws:
IOException- See Also:
-
read
Description copied from interface:ByteHolderRead a byte from this ByteHolder.The ByteHolder must be in reading mode to call this.
- Specified by:
readin interfaceByteHolder- Returns:
- The byte or -1 if there are no bytes available.
- Throws:
IOException- Thrown on error- See Also:
-
read
Description copied from interface:ByteHolderRead up to 'len' bytes from this ByteHolder and store them in an array at offset 'off'.The ByteHolder must be in reading mode to call this.
- Specified by:
readin interfaceByteHolder- Returns:
- the number of bytes read or -1 if the this ByteHolder has no more bytes.
- Throws:
IOException- Thrown on error- See Also:
-
read
Description copied from interface:ByteHolderRead from the ByteHolder.Read up to 'len' bytes from this ByteHolder and write them to the OutputStream
The ByteHolder must be in reading mode to call this.
- Specified by:
readin interfaceByteHolder- Returns:
- the number of bytes read or -1 if the this ByteHolder has no more bytes.
- Throws:
IOException- Thrown on error- See Also:
-
read
- Throws:
IOException- Thrown on error- See Also:
-
shiftToFront
Description copied from interface:ByteHoldershift the remaining unread bytes to the beginning of the byte holder- Specified by:
shiftToFrontin interfaceByteHolder- Throws:
IOException- Thrown on error- See Also:
-
available
public int available()Description copied from interface:ByteHolderReturn the number of bytes that can be read from this ByteHolder without blocking on an IO.- Specified by:
availablein interfaceByteHolder- See Also:
-
numBytesSaved
public int numBytesSaved()Return the number of bytes that have been saved to this byte holder. This result is different from available() as it is unaffected by the current read position on the ByteHolder.- Specified by:
numBytesSavedin interfaceByteHolder- See Also:
-
skip
Description copied from interface:ByteHolderSkip over the specified number of bytes in a ByteHolder.- Specified by:
skipin interfaceByteHolder- Throws:
IOException- Thrown on error- See Also:
-
writingMode
public boolean writingMode()Description copied from interface:ByteHolderReturn true if this is in writing mode.- Specified by:
writingModein interfaceByteHolder- See Also:
-
cloneEmpty
Description copied from interface:ByteHolderReturn a byte holder matching existing type and size of current ByteHolder, but don't bother to fill the bytes. Normal usage is expected to reset the holding stream to the beginning, so the copy of current state would be wasted.- Specified by:
cloneEmptyin interfaceByteHolder- Returns:
- An empty
ByteHolder. - See Also:
-
getNextBuffer_w
Get the next buffer for writing bytes.- Throws:
IOException- Thrown on error
-
getNextBuffer_w_Sanity
protected void getNextBuffer_w_Sanity()Do sanity checking when getting the next write buffer -
initBuffer_w
protected void initBuffer_w()Initialize a buffer for writing -
getNextBuffer_r
Get the next buffer for reading bytes.- Returns:
- true if the user has read all the bytes in this ByteHolder.
- Throws:
IOException- Thrown on error
-
dumpBuf
Create a string representation of an internal buffer of bytes. This is useful during debugging. -
toString
-