public class RandomAccessFilter extends AbstractRandomAccess
| Constructor and Description |
|---|
RandomAccessFilter(IRandomAccess random) |
| Modifier and Type | Method and Description |
|---|---|
void |
close()
Closes this random access data container and releases any system
resources associated with the stream.
|
void |
flush()
Force changes to be made persistent.
|
long |
getLength()
Returns the length of this data container.
|
long |
getOffset()
Returns the current offset in this data container.
|
boolean |
isReadOnly()
true if this is a read only data container. |
int |
read()
Reads a byte of data from this data container.
|
int |
read(byte[] buffer)
Reads up to
buffer.length bytes of data from this data
container into an array of bytes. |
int |
read(byte[] buffer,
int start,
int numBytes)
Reads up to
len bytes of data from this data container into
an array of bytes. |
void |
seek(long offset)
Sets the offset, measured from the beginning of the data container at
which the next read or write occurs.
|
void |
seekBy(long delta)
Sets the offset, measured from the current offset at which the next read
or write occurs.
|
void |
setLength(long newLength)
Assign the length.
|
void |
write(byte[] buffer)
Writes
b.length bytes from the specified byte array,
starting at the current offset. |
void |
write(byte[] buffer,
int start,
int numBytes)
Writes
len bytes from the specified byte array starting at
start. |
void |
write(int b)
Writes the specified byte .
|
asInputStream, asOutputStream, mark, resetpublic RandomAccessFilter(IRandomAccess random)
public void seek(long offset)
throws IOException
IRandomAccessoffset - the offset position, measured in bytes from the beginning of
the data containerIOException - if offset is less than 0 or if
an I/O error occurs.public void seekBy(long delta)
throws IOException
IRandomAccessdelta - the amount of bytes by which to change the current offset
positionIOException - if the resulting offset is less than
0 or if an I/O error occurs.public int read()
throws IOException
IRandomAccess0x00-0x0ff). This method
blocks if no input is yet available.
This method behaves in exactly the same way as the
InputStream.read() method of InputStream.
-1 if the end of the data
container has been reached.IOException - if an I/O error occurs. Not thrown if the end of the data
container has been reached.public long getOffset()
throws IOException
IRandomAccessIOException - if an I/O error occurs.public long getLength()
throws IOException
IRandomAccessIOException - if an I/O error occurs.public void setLength(long newLength)
throws IOException
IRandomAccessIOExceptionpublic int read(byte[] buffer)
throws IOException
IRandomAccessbuffer.length bytes of data from this data
container into an array of bytes. This method blocks until at least one
byte of input is available.
This method behaves in the exactly the same way as the
InputStream.read(byte[]) method of InputStream.
buffer - the buffer into which the data is read.-1 if there is no more data because the end of this
data container has been reached.IOException - if an I/O error occurs.public int read(byte[] buffer,
int start,
int numBytes)
throws IOException
IRandomAccesslen bytes of data from this data container into
an array of bytes. This method blocks until at least one byte of input is
available.
buffer - the buffer into which the data is read.start - the start offset of the data.numBytes - the maximum number of bytes read.-1 if there is no more data because the end of the
file has been reached.IOException - if an I/O error occurs.public void close()
throws IOException
IRandomAccessIOException - if an I/O error occurs.public void flush()
throws IOException
IRandomAccessIOExceptionpublic boolean isReadOnly()
IRandomAccesstrue if this is a read only data container.true if this is a read only data container.public void write(int b)
throws IOException
IRandomAccessb - the byte to be written.IOException - if an I/O error occurs.public void write(byte[] buffer)
throws IOException
IRandomAccessb.length bytes from the specified byte array,
starting at the current offset.buffer - the data.IOException - if an I/O error occurs.public void write(byte[] buffer,
int start,
int numBytes)
throws IOException
IRandomAccesslen bytes from the specified byte array starting at
start.buffer - the data.start - the start offset in the data.numBytes - the number of bytes to write.IOException - if an I/O error occurs.Copyright © 2013 intarsys consulting GmbH. All Rights Reserved.