public class LazyRandomAccessFileByteWriter extends Object implements ByteWriter
RandomAccessFile. It will not open the
File until the first attempt to read or operate on that
File. At that point a
RandomAccessFileByteReader
will be constructed and used.
This class is not threadsafe. It is not safe to pass an instance of this class
to multiple threads. It is not safe to pass an instance of this class to multiple users even
if in the same thread.EOF| Constructor and Description |
|---|
LazyRandomAccessFileByteWriter(File file) |
| Modifier and Type | Method and Description |
|---|---|
void |
close()
Closes this
ByteReader and releases any system resources
associated with this stream. |
void |
flush()
Flushes this
ByteWriter and forces any buffered output bytes to be written out. |
long |
length()
Returns the number of total bytes in the repository that are visible through
this API.
|
int |
read(long position)
Read a single byte from the underlying bytes at the given position.
|
int |
read(long position,
byte[] b,
int offset,
int length)
Transfers bytes from the underlying repository into the given destination array.
|
void |
write(long position,
byte[] b,
int offset,
int length)
Write an array of bytes at the position given.
|
void |
write(long position,
int b)
Write the byte given at the position given.
|
public LazyRandomAccessFileByteWriter(File file) throws IOException
file - IOExceptionpublic int read(long position)
throws IOException
ByteReaderread in interface ByteReaderposition - the position to read the byte from.IOException - if an error occurs during the read operationByteReader.read(long)public int read(long position,
byte[] b,
int offset,
int length)
throws IOException
ByteReaderlength bytes from the repository starting at the postion
given into the given array starting at the given offset.read in interface ByteReaderposition - the position to read the byte from.b - the array to write the bytes into.offset - the offset in the array at which the first byte is written.length - the maximum number of bytes to write into the array.IOException - if an error occurs during the read operationByteReader.read(long, byte[], int, int)public long length()
throws IOException
ByteReaderlength in interface ByteReaderIOException - if an error occurs while trying to determine the lengthByteReader.length()public void close()
throws IOException
ByteReaderByteReader and releases any system resources
associated with this stream.close in interface ByteReaderIOException - if an error occurs while trying to closeByteReader.close()public void write(long position,
int b)
throws IOException
write in interface ByteWriterposition - the zero-based offset within the byte array.b - the byte to write.IOExceptionpublic void write(long position,
byte[] b,
int offset,
int length)
throws IOException
write in interface ByteWriterposition - the zero-based offset within the byte array.b - the array of bytes to write from.offset - the offset within the byte array to start writing from.length - the number of bytes to write from the byte array.IOExceptionpublic void flush()
throws IOException
ByteWriter and forces any buffered output bytes to be written out.flush in interface ByteWriterIOExceptionCopyright © 2010 - 2020 Adobe. All Rights Reserved