public class ISRandomAccessIO extends Object implements RandomAccessIO
The cache grows automatically as necessary. However, if the data length is known prior to the creation of a ISRandomAccessIO object, it is best to specify that as the initial in-memory buffer size. That will minimize data copying and multiple allocation.
Multi-byte data is read in big-endian order. The in-memory buffer storage is released when 'close()' is called. This class can only be used for data input, not output. The wrapped InputStream is closed when all the input data is cached or when 'close()' is called.
If an out of memory condition is encountered when growing the in-memory buffer an IOException is thrown instead of an OutOfMemoryError. The exception message is "Out of memory to cache input data".
This class is intended for use as a "quick and dirty" way to give network connectivity to RandomAccessIO based classes. It is not intended as an efficient means of implementing network connectivity. Doing such requires reimplementing the RandomAccessIO based classes to directly use network connections.
This class does not use temporary files as buffers, because that would preclude the use in unsigned applets.
| Modifier and Type | Field and Description |
|---|---|
private byte[] |
buf |
private boolean |
complete |
private int |
inc |
private InputStream |
is
The InputStream that is wrapped
|
private int |
len |
private int |
maxsize |
private int |
pos |
| Constructor and Description |
|---|
ISRandomAccessIO(InputStream is)
Creates a new RandomAccessIO wrapper for the given InputStream
'is'.
|
ISRandomAccessIO(InputStream is,
int size,
int inc,
int maxsize)
Creates a new RandomAccessIO wrapper for the given InputStream
'is'.
|
| Modifier and Type | Method and Description |
|---|---|
void |
close()
Closes this object for reading as well as the wrapped InputStream, if
not already closed.
|
void |
flush()
Does nothing since this class does not implement data output.
|
int |
getByteOrdering()
Returns the endianess (i.e., byte ordering) of multi-byte I/O
operations.
|
int |
getPos()
Returns the current position in the stream, which is the
position from where the next byte of data would be read.
|
private void |
growBuffer()
Grows the cache buffer by 'inc', upto a maximum of 'maxsize'.
|
int |
length()
Returns the length of the stream.
|
int |
read()
Reads a byte of data from the stream.
|
byte |
readByte()
Reads a signed byte (8 bit) from the input.
|
double |
readDouble()
Reads an IEEE double precision (i.e., 64 bit) floating-point number
from the input.
|
float |
readFloat()
Reads an IEEE single precision (i.e., 32 bit) floating-point number
from the input.
|
void |
readFully(byte[] b,
int off,
int n)
Reads 'len' bytes of data from this file into an array of bytes.
|
private void |
readInput()
Reads data from the wrapped InputStream and places it in the cache
buffer.
|
int |
readInt()
Reads a signed int (32 bit) from the input.
|
long |
readLong()
Reads a signed long (64 bit) from the input.
|
short |
readShort()
Reads a signed short (16 bit) from the input.
|
int |
readUnsignedByte()
Reads an unsigned byte (8 bit) from the input.
|
long |
readUnsignedInt()
Reads a unsigned int (32 bit) from the input.
|
int |
readUnsignedShort()
Reads an unsigned short (16 bit) from the input.
|
void |
seek(int off)
Moves the current position for the next read operation to
offset.
|
int |
skipBytes(int n)
Skips 'n' bytes from the input.
|
void |
write(int b)
Throws an IOException since this class does not implement data output.
|
void |
writeByte(int v)
Throws an IOException since this class does not implement data output.
|
void |
writeDouble(double v)
Throws an IOException since this class does not implement data output.
|
void |
writeFloat(float v)
Throws an IOException since this class does not implement data output.
|
void |
writeInt(int v)
Throws an IOException since this class does not implement data output.
|
void |
writeLong(long v)
Throws an IOException since this class does not implement data output.
|
void |
writeShort(int v)
Throws an IOException since this class does not implement data output.
|
private InputStream is
private int maxsize
private int inc
private byte[] buf
private int len
private int pos
private boolean complete
public ISRandomAccessIO(InputStream is, int size, int inc, int maxsize)
is - The input from where to get the data.size - The initial size for the cache buffer, in bytes.inc - The size increment for the cache buffer, in bytes.maxsize - The maximum size for the cache buffer, in bytes.public ISRandomAccessIO(InputStream is)
is - The input from where to get the data.private void growBuffer()
throws IOException
IOException - If the maximum cache size is reached or if not
enough memory is available to grow the buffer.private void readInput()
throws IOException
IOException - An I/O error occurred, out of meory to grow
cache or maximum cache size reached.public void close()
throws IOException
close in interface RandomAccessIOIOException - If an I/O error occurs while closing the
underlying InputStream.public int getPos()
throws IOException
getPos in interface RandomAccessIOIOException - If an I/O error occurred.public void seek(int off)
throws IOException
seek in interface RandomAccessIOoff - The offset where to move to.EOFException - If seeking beyond EOF and the data length is
known.IOException - If an I/O error ocurred.public int length()
throws IOException
length in interface RandomAccessIOIOException - If an I/O error ocurred.public int read()
throws IOException
read in interface RandomAccessIOEOFException - If the end-of file was reached.IOException - If an I/O error ocurred.public void readFully(byte[] b,
int off,
int n)
throws IOException
readFully in interface RandomAccessIOb - The buffer into which the data is to be read. It must be long
enough.off - The index in 'b' where to place the first byte read.n - The number of bytes to read.EOFException - If the end-of file was reached before
getting all the necessary data.IOException - If an I/O error ocurred.public int getByteOrdering()
getByteOrdering in interface BinaryDataInputgetByteOrdering in interface BinaryDataOutputEndianTypepublic byte readByte()
throws IOException
readByte in interface BinaryDataInputEOFException - If the end-of file was reached before
getting all the necessary data.IOException - If an I/O error ocurred.public int readUnsignedByte()
throws IOException
readUnsignedByte in interface BinaryDataInputEOFException - If the end-of file was reached before
getting all the necessary data.IOException - If an I/O error ocurred.public short readShort()
throws IOException
readShort in interface BinaryDataInputEOFException - If the end-of file was reached before
getting all the necessary data.IOException - If an I/O error ocurred.public int readUnsignedShort()
throws IOException
readUnsignedShort in interface BinaryDataInputEOFException - If the end-of file was reached before
getting all the necessary data.IOException - If an I/O error ocurred.public int readInt()
throws IOException
readInt in interface BinaryDataInputEOFException - If the end-of file was reached before
getting all the necessary data.IOException - If an I/O error ocurred.public long readUnsignedInt()
throws IOException
readUnsignedInt in interface BinaryDataInputEOFException - If the end-of file was reached before
getting all the necessary data.IOException - If an I/O error ocurred.public long readLong()
throws IOException
readLong in interface BinaryDataInputEOFException - If the end-of file was reached before
getting all the necessary data.IOException - If an I/O error ocurred.public float readFloat()
throws IOException
readFloat in interface BinaryDataInputEOFException - If the end-of file was reached before
getting all the necessary data.IOException - If an I/O error ocurred.public double readDouble()
throws IOException
readDouble in interface BinaryDataInputEOFException - If the end-of file was reached before
getting all the necessary data.IOException - If an I/O error ocurred.public int skipBytes(int n)
throws IOException
skipBytes in interface BinaryDataInputn - The number of bytes to skipEOFException - If the end-of file was reached before
all the bytes could be skipped.IOException - If an I/O error ocurred.public void flush()
flush in interface BinaryDataOutputpublic void write(int b)
throws IOException
write in interface RandomAccessIOb - The byte to write. The lower 8 bits of b are
written.IOException - If an I/O error ocurred.public void writeByte(int v)
throws IOException
writeByte in interface BinaryDataOutputv - The value to write to the outputIOException - If an I/O error ocurred.public void writeShort(int v)
throws IOException
writeShort in interface BinaryDataOutputv - The value to write to the outputIOException - If an I/O error ocurred.public void writeInt(int v)
throws IOException
writeInt in interface BinaryDataOutputv - The value to write to the outputIOException - If an I/O error ocurred.public void writeLong(long v)
throws IOException
writeLong in interface BinaryDataOutputv - The value to write to the outputIOException - If an I/O error ocurred.public void writeFloat(float v)
throws IOException
writeFloat in interface BinaryDataOutputv - The value to write to the outputIOException - If an I/O error ocurred.public void writeDouble(double v)
throws IOException
writeDouble in interface BinaryDataOutputv - The value to write to the outputIOException - If an I/O error ocurred.Copyright © 2015 Open Microscopy Environment