| java.lang.Object | |
| ↳ | java.io.RandomAccessFile | 
Allows reading from and writing to a file in a random-access manner. This is different from the uni-directional sequential access that a FileInputStream or FileOutputStream provides. If the file is opened in read/write mode, write operations are available as well. The position of the next read or write operation can be moved forwards and backwards after every operation.
| Public Constructors | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|
| Constructs a new  RandomAccessFilebased onfileand opens
 it according to the access string inmode. | |||||||||||
| Constructs a new  RandomAccessFilebased on the file namedfileNameand opens it according to the access string inmode. | |||||||||||
| Public Methods | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|
| Closes this file. | |||||||||||
| Gets this file's FileChannel object. | |||||||||||
| Gets this file's FileDescriptor. | |||||||||||
| Gets the current position within this file. | |||||||||||
| Returns the length of this file in bytes. | |||||||||||
| Reads at most  countbytes from the current position in this file
 and stores them in the byte arraybufferstarting atoffset. | |||||||||||
| Reads a single byte from the current position in this file and returns it
 as an integer in the range from 0 to 255. | |||||||||||
| Reads bytes from the current position in this file and stores them in the
 byte array  buffer. | |||||||||||
| Reads a boolean from the current position in this file. | |||||||||||
| Reads an 8-bit byte from the current position in this file. | |||||||||||
| Reads a 16-bit character from the current position in this file. | |||||||||||
| Reads a 64-bit double from the current position in this file. | |||||||||||
| Reads a 32-bit float from the current position in this file. | |||||||||||
| Read bytes from this file into  bufferstarting at offsetoffset. | |||||||||||
| Reads bytes from this file into  buffer. | |||||||||||
| Reads a 32-bit integer from the current position in this file. | |||||||||||
| Reads a line of text form the current position in this file. | |||||||||||
| Reads a 64-bit long from the current position in this file. | |||||||||||
| Reads a 16-bit short from the current position in this file. | |||||||||||
| Reads a string that is encoded in modified UTF-8 from
 this file. | |||||||||||
| Reads an unsigned 8-bit byte from the current position in this file and
 returns it as an integer. | |||||||||||
| Reads an unsigned 16-bit short from the current position in this file and
 returns it as an integer. | |||||||||||
| Moves this file's file pointer to a new position, from where following
  read,writeorskipoperations are done. | |||||||||||
| Sets the length of this file to  newLength. | |||||||||||
| Skips over  countbytes in this file. | |||||||||||
| Writes  countbytes from the byte arraybufferto this
 file, starting at the current file pointer and usingoffsetas
 the first position withinbufferto get bytes. | |||||||||||
| Writes a byte to this file, starting at the current file pointer. | |||||||||||
| Writes the entire contents of the byte array  bufferto this file,
 starting at the current file pointer. | |||||||||||
| Writes a boolean to this file, starting at the current file pointer. | |||||||||||
| Writes an 8-bit byte to this file, starting at the current file pointer. | |||||||||||
| Writes the low order 8-bit bytes from a string to this file, starting at
 the current file pointer. | |||||||||||
| Writes a 16-bit character to this file, starting at the current file
 pointer. | |||||||||||
| Writes the 16-bit characters from a string to this file, starting at the
 current file pointer. | |||||||||||
| Writes a 64-bit double to this file, starting at the current file
 pointer. | |||||||||||
| Writes a 32-bit float to this file, starting at the current file pointer. | |||||||||||
| Writes a 32-bit integer to this file, starting at the current file
 pointer. | |||||||||||
| Writes a 64-bit long to this file, starting at the current file
 pointer. | |||||||||||
| Writes a 16-bit short to this file, starting at the current file
 pointer. | |||||||||||
| Writes a string encoded with modified UTF-8 to this
 file, starting at the current file pointer. | |||||||||||
| [Expand] Inherited Methods | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|
|  From class java.lang.Object | |||||||||||
|  From interface java.io.Closeable | |||||||||||
|  From interface java.io.DataInput | |||||||||||
|  From interface java.io.DataOutput | |||||||||||
Constructs a new RandomAccessFile based on file and opens
 it according to the access string in mode. 
 
 mode may have one of following values: 
 
| "r" | The file is opened in read-only mode. An IOExceptionis
 thrown if any of thewritemethods is called. | 
| "rw" | The file is opened for reading and writing. If the file does not exist, it will be created. | 
| "rws" | The file is opened for reading and writing. Every change of the file's content or metadata must be written synchronously to the target device. | 
| "rwd" | The file is opened for reading and writing. Every change of the file's content must be written synchronously to the target device. | 
| file | the file to open. | 
|---|---|
| mode | the file access mode, either "r","rw","rws"or"rwd". | 
| FileNotFoundException | if the file cannot be opened or created according to mode. | 
|---|---|
| IllegalArgumentException | if modeis not"r","rw","rws"or"rwd". | 
| SecurityException | if a SecurityManageris installed and it denies
             access request according tomode. | 
Constructs a new RandomAccessFile based on the file named fileName and opens it according to the access string in mode.
 The file path may be specified absolutely or relative to the system
 property "user.dir".
| fileName | the name of the file to open. | 
|---|---|
| mode | the file access mode, either "r","rw","rws"or"rwd". | 
| FileNotFoundException | if the file cannot be opened or created according to mode. | 
|---|---|
| IllegalArgumentException | if modeis not"r","rw","rws"or"rwd". | 
| SecurityException | if a SecurityManageris installed and it denies
             access request according tomode. | 
Closes this file.
| IOException | if an error occurs while closing this file. | 
|---|
Gets this file's FileChannel object.
The file channel's position is the same as this file's file pointer offset (see getFilePointer()). Any changes made to this file's file pointer offset are also visible in the file channel's position and vice versa.
Gets this file's FileDescriptor. This represents the operating system resource for this random access file.
| IOException | if an error occurs while getting the file descriptor of this file. | 
|---|
Gets the current position within this file. All reads and writes take place at the current file pointer position.
| IOException | if an error occurs while getting the file pointer of this file. | 
|---|
Returns the length of this file in bytes.
| IOException | if this file is closed or some other I/O error occurs. | 
|---|
Reads at most count bytes from the current position in this file
 and stores them in the byte array buffer starting at offset. Blocks until count bytes have been read, the end of the
 file is reached or an exception is thrown.
| buffer | the array in which to store the bytes read from this file. | 
|---|---|
| offset | the initial position in bufferto store the bytes read
            from this file. | 
| count | the maximum number of bytes to store in buffer. | 
| IndexOutOfBoundsException | if offset < 0orcount < 0, or ifoffset + countis greater than the size ofbuffer. | 
|---|---|
| IOException | if this file is closed or another I/O error occurs. | 
Reads a single byte from the current position in this file and returns it as an integer in the range from 0 to 255. Returns -1 if the end of the file has been reached. Blocks until one byte has been read, the end of the file is detected or an exception is thrown.
| IOException | if this file is closed or another I/O error occurs. | 
|---|
Reads bytes from the current position in this file and stores them in the
 byte array buffer. The maximum number of bytes read corresponds
 to the size of buffer. Blocks until at least one byte has been
 read.
| buffer | the byte array in which to store the bytes read. | 
|---|
| IOException | if this file is closed or another I/O error occurs. | 
|---|
Reads a boolean from the current position in this file. Blocks until one byte has been read, the end of the file is reached or an exception is thrown.
| EOFException | if the end of this file is detected. | 
|---|---|
| IOException | if this file is closed or another I/O error occurs. | 
Reads an 8-bit byte from the current position in this file. Blocks until one byte has been read, the end of the file is reached or an exception is thrown.
| EOFException | if the end of this file is detected. | 
|---|---|
| IOException | if this file is closed or another I/O error occurs. | 
Reads a 16-bit character from the current position in this file. Blocks until two bytes have been read, the end of the file is reached or an exception is thrown.
| EOFException | if the end of this file is detected. | 
|---|---|
| IOException | if this file is closed or another I/O error occurs. | 
Reads a 64-bit double from the current position in this file. Blocks until eight bytes have been read, the end of the file is reached or an exception is thrown.
| EOFException | if the end of this file is detected. | 
|---|---|
| IOException | if this file is closed or another I/O error occurs. | 
Reads a 32-bit float from the current position in this file. Blocks until four bytes have been read, the end of the file is reached or an exception is thrown.
| EOFException | if the end of this file is detected. | 
|---|---|
| IOException | if this file is closed or another I/O error occurs. | 
Read bytes from this file into buffer starting at offset offset. This method blocks until count number of bytes have been
 read.
| buffer | the buffer to read bytes into. | 
|---|---|
| offset | the initial position in bufferto store the bytes read
            from this file. | 
| count | the maximum number of bytes to store in buffer. | 
| EOFException | if the end of this file is detected. | 
|---|---|
| IndexOutOfBoundsException | if offset < 0orcount < 0, or ifoffset + countis greater than the length ofbuffer. | 
| IOException | if this file is closed or another I/O error occurs. | 
| NullPointerException | if bufferisnull. | 
Reads bytes from this file into buffer. Blocks until buffer.length number of bytes have been read, the end of the file is
 reached or an exception is thrown.
| buffer | the buffer to read bytes into. | 
|---|
| EOFException | if the end of this file is detected. | 
|---|---|
| IOException | if this file is closed or another I/O error occurs. | 
| NullPointerException | if bufferisnull. | 
Reads a 32-bit integer from the current position in this file. Blocks until four bytes have been read, the end of the file is reached or an exception is thrown.
| EOFException | if the end of this file is detected. | 
|---|---|
| IOException | if this file is closed or another I/O error occurs. | 
Reads a line of text form the current position in this file. A line is
 represented by zero or more characters followed by '\n', '\r', "\r\n" or the end of file marker. The string does not
 include the line terminating sequence.
 
Blocks until a line terminating sequence has been read, the end of the file is reached or an exception is thrown.
null if no characters have
         been read before the end of the file has been reached.| IOException | if this file is closed or another I/O error occurs. | 
|---|
Reads a 64-bit long from the current position in this file. Blocks until eight bytes have been read, the end of the file is reached or an exception is thrown.
| EOFException | if the end of this file is detected. | 
|---|---|
| IOException | if this file is closed or another I/O error occurs. | 
Reads a 16-bit short from the current position in this file. Blocks until two bytes have been read, the end of the file is reached or an exception is thrown.
| EOFException | if the end of this file is detected. | 
|---|---|
| IOException | if this file is closed or another I/O error occurs. | 
Reads a string that is encoded in modified UTF-8 from this file. The number of bytes that must be read for the complete string is determined by the first two bytes read from the file. Blocks until all required bytes have been read, the end of the file is reached or an exception is thrown.
| EOFException | if the end of this file is detected. | 
|---|---|
| IOException | if this file is closed or another I/O error occurs. | 
| UTFDataFormatException | if the bytes read cannot be decoded into a character string. | 
Reads an unsigned 8-bit byte from the current position in this file and returns it as an integer. Blocks until one byte has been read, the end of the file is reached or an exception is thrown.
| EOFException | if the end of this file is detected. | 
|---|---|
| IOException | if this file is closed or another I/O error occurs. | 
Reads an unsigned 16-bit short from the current position in this file and returns it as an integer. Blocks until two bytes have been read, the end of the file is reached or an exception is thrown.
| EOFException | if the end of this file is detected. | 
|---|---|
| IOException | if this file is closed or another I/O error occurs. | 
Moves this file's file pointer to a new position, from where following
 read, write or skip operations are done. The
 position may be greater than the current length of the file, but the
 file's length will only change if the moving of the pointer is followed
 by a write operation.
| pos | the new file pointer position. | 
|---|
| IOException | if this file is closed, pos < 0or another I/O error
             occurs. | 
|---|
Sets the length of this file to newLength. If the current file is
 smaller, it is expanded but the contents from the previous end of the
 file to the new end are undefined. The file is truncated if its current
 size is bigger than newLength. If the current file pointer
 position is in the truncated part, it is set to the end of the file.
| newLength | the new file length in bytes. | 
|---|
| IllegalArgumentException | if newLength < 0. | 
|---|---|
| IOException | if this file is closed or another I/O error occurs. | 
Skips over count bytes in this file. Less than count
 bytes are skipped if the end of the file is reached or an exception is
 thrown during the operation. Nothing is done if count is
 negative.
| count | the number of bytes to skip. | 
|---|
| IOException | if this file is closed or another I/O error occurs. | 
|---|
Writes count bytes from the byte array buffer to this
 file, starting at the current file pointer and using offset as
 the first position within buffer to get bytes.
| buffer | the buffer to write to this file. | 
|---|---|
| offset | the index of the first byte in bufferto write. | 
| count | the number of bytes from bufferto write. | 
| IndexOutOfBoundsException | if count < 0,offset < 0orcount +
             offsetis greater than the size ofbuffer. | 
|---|---|
| IOException | if an I/O error occurs while writing to this file. | 
Writes a byte to this file, starting at the current file pointer. Only
 the least significant byte of the integer oneByte is written.
| oneByte | the byte to write to this file. | 
|---|
| IOException | if this file is closed or another I/O error occurs. | 
|---|
Writes the entire contents of the byte array buffer to this file,
 starting at the current file pointer.
| buffer | the buffer to write. | 
|---|
| IOException | if an I/O error occurs while writing to this file. | 
|---|
Writes a boolean to this file, starting at the current file pointer.
| val | the boolean to write to this file. | 
|---|
| IOException | if this file is closed or another I/O error occurs. | 
|---|
Writes an 8-bit byte to this file, starting at the current file pointer.
 Only the least significant byte of the integer val is written.
| val | the byte to write to this file. | 
|---|
| IOException | if this file is closed or another I/O error occurs. | 
|---|
Writes the low order 8-bit bytes from a string to this file, starting at the current file pointer.
| str | the string containing the bytes to write to this file | 
|---|
| IOException | if an I/O error occurs while writing to this file. | 
|---|
Writes a 16-bit character to this file, starting at the current file
 pointer. Only the two least significant bytes of the integer val
 are written, with the high byte first.
| val | the char to write to this file. | 
|---|
| IOException | if an I/O error occurs while writing to this file. | 
|---|
Writes the 16-bit characters from a string to this file, starting at the current file pointer. Each character is written in the same way as with writeChar(int), with its high byte first.
| str | the string to write to this file. | 
|---|
| IOException | if an I/O error occurs while writing to this file. | 
|---|
Writes a 64-bit double to this file, starting at the current file pointer. The eight bytes returned by doubleToLongBits(double) are written to this file.
| val | the double to write to this file. | 
|---|
| IOException | if an I/O error occurs while writing to this file. | 
|---|
Writes a 32-bit float to this file, starting at the current file pointer. The four bytes returned by floatToIntBits(float) are written to this file.
| val | the float to write to this file. | 
|---|
| IOException | if an I/O error occurs while writing to this file. | 
|---|
Writes a 32-bit integer to this file, starting at the current file pointer. The four bytes of the integer are written with the highest byte first.
| val | the int to write to this file. | 
|---|
| IOException | if an I/O error occurs while writing to this file. | 
|---|
Writes a 64-bit long to this file, starting at the current file pointer. The eight bytes of the long are written with the highest byte first.
| val | the long to write to this file. | 
|---|
| IOException | if an I/O error occurs while writing to this file. | 
|---|
Writes a 16-bit short to this file, starting at the current file
 pointer. Only the two least significant bytes of the integer val
 are written, with the high byte first.
| val | the short to write to this file. | 
|---|
| IOException | if an I/O error occurs while writing to this file. | 
|---|
Writes a string encoded with modified UTF-8 to this file, starting at the current file pointer.
| str | the string to write in modified UTF-8 format. | 
|---|
| IOException | if an I/O error occurs while writing to this file. | 
|---|---|
| UTFDataFormatException | if the encoded string is longer than 65535 bytes. |