public abstract class ByteBufferIndexInput extends IndexInput implements RandomAccessInput
Because Java's ByteBuffer uses an int to address the values, it's necessary to access a file greater Integer.MAX_VALUE in size using multiple byte buffers.
For efficiency, this class requires that the buffers
are a power-of-two (chunkSizePower).
| Modifier and Type | Field and Description |
|---|---|
protected ByteBuffer[] |
buffers |
protected long |
chunkSizeMask |
protected int |
chunkSizePower |
protected ByteBuffer |
curBuf |
protected int |
curBufIndex |
protected org.apache.lucene.store.ByteBufferGuard |
guard |
protected boolean |
isClone |
protected long |
length |
| Modifier and Type | Method and Description |
|---|---|
protected ByteBufferIndexInput |
buildSlice(String sliceDescription,
long offset,
long length)
Builds the actual sliced IndexInput (may apply extra offset in subclasses).
|
ByteBufferIndexInput |
clone()
Returns a clone of this stream.
|
void |
close()
Closes the stream to further operations.
|
long |
getFilePointer()
Returns the current position in this file, where the next read will
occur.
|
long |
length()
The number of bytes in the file.
|
protected ByteBufferIndexInput |
newCloneInstance(String newResourceDescription,
ByteBuffer[] newBuffers,
int offset,
long length)
Factory method that creates a suitable implementation of this class for the given ByteBuffers.
|
static ByteBufferIndexInput |
newInstance(String resourceDescription,
ByteBuffer[] buffers,
long length,
int chunkSizePower,
org.apache.lucene.store.ByteBufferGuard guard) |
byte |
readByte()
Reads and returns a single byte.
|
byte |
readByte(long pos)
Reads a byte at the given position in the file
|
void |
readBytes(byte[] b,
int offset,
int len)
Reads a specified number of bytes into an array at the specified offset.
|
int |
readInt()
Reads four bytes and returns an int.
|
int |
readInt(long pos)
Reads an integer at the given position in the file
|
long |
readLong()
Reads eight bytes and returns a long.
|
long |
readLong(long pos)
Reads a long at the given position in the file
|
short |
readShort()
Reads two bytes and returns a short.
|
short |
readShort(long pos)
Reads a short at the given position in the file
|
void |
seek(long pos)
Sets current position in this file, where the next read will occur.
|
ByteBufferIndexInput |
slice(String sliceDescription,
long offset,
long length)
Creates a slice of this index input, with the given description, offset, and length.
|
getFullSliceDescription, randomAccessSlice, toStringreadBytes, readMapOfStrings, readSetOfStrings, readString, readVInt, readVLong, readZInt, readZLong, skipBytesprotected final long length
protected final long chunkSizeMask
protected final int chunkSizePower
protected final org.apache.lucene.store.ByteBufferGuard guard
protected ByteBuffer[] buffers
protected int curBufIndex
protected ByteBuffer curBuf
protected boolean isClone
public static ByteBufferIndexInput newInstance(String resourceDescription, ByteBuffer[] buffers, long length, int chunkSizePower, org.apache.lucene.store.ByteBufferGuard guard)
public final byte readByte()
throws IOException
DataInputreadByte in class DataInputIOExceptionDataOutput.writeByte(byte)public final void readBytes(byte[] b,
int offset,
int len)
throws IOException
DataInputreadBytes in class DataInputb - the array to read bytes intooffset - the offset in the array to start storing byteslen - the number of bytes to readIOExceptionDataOutput.writeBytes(byte[],int)public final short readShort()
throws IOException
DataInputreadShort in class DataInputIOExceptionDataOutput.writeByte(byte)public final int readInt()
throws IOException
DataInputreadInt in class DataInputIOExceptionDataOutput.writeInt(int)public final long readLong()
throws IOException
DataInputreadLong in class DataInputIOExceptionDataOutput.writeLong(long)public long getFilePointer()
IndexInputgetFilePointer in class IndexInputIndexInput.seek(long)public void seek(long pos)
throws IOException
IndexInputEOFException and then the
stream is in an undetermined state.seek in class IndexInputIOExceptionIndexInput.getFilePointer()public byte readByte(long pos)
throws IOException
RandomAccessInputreadByte in interface RandomAccessInputIOExceptionDataInput.readByte()public short readShort(long pos)
throws IOException
RandomAccessInputreadShort in interface RandomAccessInputIOExceptionDataInput.readShort()public int readInt(long pos)
throws IOException
RandomAccessInputreadInt in interface RandomAccessInputIOExceptionDataInput.readInt()public long readLong(long pos)
throws IOException
RandomAccessInputreadLong in interface RandomAccessInputIOExceptionDataInput.readLong()public final long length()
IndexInputlength in class IndexInputpublic final ByteBufferIndexInput clone()
IndexInputClones of a stream access the same data, and are positioned at the same point as the stream they were cloned from.
Expert: Subclasses must ensure that clones may be positioned at different points in the input from each other and from the stream they were cloned from.
Warning: Lucene never closes cloned
IndexInputs, it will only call IndexInput.close() on the original object.
If you access the cloned IndexInput after closing the original object,
any readXXX methods will throw AlreadyClosedException.
This method is NOT thread safe, so if the current IndexInput
is being used by one thread while clone is called by another,
disaster could strike.
clone in class IndexInputpublic final ByteBufferIndexInput slice(String sliceDescription, long offset, long length)
slice in class IndexInputprotected ByteBufferIndexInput buildSlice(String sliceDescription, long offset, long length)
protected ByteBufferIndexInput newCloneInstance(String newResourceDescription, ByteBuffer[] newBuffers, int offset, long length)
public final void close()
throws IOException
IndexInputclose in interface Closeableclose in interface AutoCloseableclose in class IndexInputIOExceptionCopyright © 2000-2019 Apache Software Foundation. All Rights Reserved.