Package org.eclipse.rdf4j.common.io
Class NioFile
java.lang.Object
org.eclipse.rdf4j.common.io.NioFile
- All Implemented Interfaces:
- Closeable,- AutoCloseable
File wrapper that protects against concurrent file closing events due to e.g. 
thread
 interrupts. In case the file channel that is used by this class is closed due to such an event, it will try to
 reopen the channel. The thread that causes the ClosedByInterruptException is not protected, assuming the
 interrupt is intended to end the thread's operation.- Author:
- Arjohn Kampman
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final EnumSet<StandardOpenOption>static final EnumSet<StandardOpenOption>static final EnumSet<StandardOpenOption>static final EnumSet<StandardOpenOption>
- 
Constructor SummaryConstructorsConstructorDescriptionConstructor Opens a file in read/write mode, creating a new one if the file doesn't exist.Constructor Opens a file in a specific mode, creating a new one if the file doesn't exist.NioFile(File file, Set<StandardOpenOption> openOptions) NioFile(Path path, Set<StandardOpenOption> openOptions) 
- 
Method SummaryModifier and TypeMethodDescriptionvoidclose()booleandelete()Close any open channels and then deletes the file.voidforce(boolean metaData) Performs a protectedFileChannel.force(boolean)call.getFile()booleanisClosed()Check if a file was closed explicitly.intread(ByteBuffer buf, long offset) Performs a protectedFileChannel.read(ByteBuffer, long)call.bytereadByte(long offset) Read single byte from channel starting at offset.byte[]readBytes(long offset, int length) Read a byte array of a specific length from channel starting at offset.intreadInt(long offset) Read integer value from channel starting at offset.longreadLong(long offset) Read long value from channel starting at offset.longsize()Performs a protectedFileChannel.size()call.longtransferTo(long position, long count, WritableByteChannel target) Performs a protectedFileChannel.transferTo(long, long, WritableByteChannel)call.voidtruncate(long size) Performs a protectedFileChannel.truncate(long)call.intwrite(ByteBuffer buf, long offset) Performs a protectedFileChannel.write(ByteBuffer, long)call.voidwriteByte(byte value, long offset) Write single byte to channel starting at offset.voidwriteBytes(byte[] value, long offset) Write byte array to channel starting at offset.voidwriteInt(int value, long offset) Write integer value to channel starting at offset.voidwriteLong(long value, long offset) Write long value to channel starting at offset.
- 
Field Details- 
R
- 
RW
- 
RWS
- 
RWD
 
- 
- 
Constructor Details- 
NioFileConstructor Opens a file in read/write mode, creating a new one if the file doesn't exist.- Parameters:
- file-
- Throws:
- IOException
 
- 
NioFileConstructor Opens a file in a specific mode, creating a new one if the file doesn't exist.- Parameters:
- file- file
- mode- file mode
- Throws:
- IOException
 
- 
NioFile- Throws:
- IOException
 
- 
NioFile- Throws:
- IOException
 
 
- 
- 
Method Details- 
close- Specified by:
- closein interface- AutoCloseable
- Specified by:
- closein interface- Closeable
- Throws:
- IOException
 
- 
isClosedpublic boolean isClosed()Check if a file was closed explicitly.- Returns:
- true if it was closed explicitly
 
- 
getFile
- 
deleteClose any open channels and then deletes the file.- Returns:
- true if the file has been deleted successfully, false otherwise.
- Throws:
- IOException- If there was a problem closing the open file channel.
 
- 
forcePerforms a protectedFileChannel.force(boolean)call.- Parameters:
- metaData-
- Throws:
- IOException
 
- 
truncatePerforms a protectedFileChannel.truncate(long)call.- Parameters:
- size-
- Throws:
- IOException
 
- 
sizePerforms a protectedFileChannel.size()call.- Returns:
- size of the file
- Throws:
- IOException
 
- 
transferToPerforms a protectedFileChannel.transferTo(long, long, WritableByteChannel)call.- Parameters:
- position- position within the file
- count- number of bytes to transfer
- target- target channel
- Returns:
- number of bytes transferred
- Throws:
- IOException
 
- 
writePerforms a protectedFileChannel.write(ByteBuffer, long)call.- Parameters:
- buf- buffer
- offset- non-negative offset
- Returns:
- number of bytes written
- Throws:
- IOException
 
- 
readPerforms a protectedFileChannel.read(ByteBuffer, long)call.- Parameters:
- buf- buffer to read
- offset- non-negative offset
- Returns:
- number of bytes read
- Throws:
- IOException
 
- 
writeBytesWrite byte array to channel starting at offset.- Parameters:
- value- byte array to write
- offset- non-negative offset
- Throws:
- IOException
 
- 
readBytesRead a byte array of a specific length from channel starting at offset.- Parameters:
- offset-
- length-
- Returns:
- byte array
- Throws:
- IOException
 
- 
writeByteWrite single byte to channel starting at offset.- Parameters:
- value- value to write
- offset- non-negative offset
- Throws:
- IOException
 
- 
readByteRead single byte from channel starting at offset.- Parameters:
- offset- non-negative offset
- Returns:
- byte
- Throws:
- IOException
 
- 
writeLongWrite long value to channel starting at offset.- Parameters:
- value- value to write
- offset- non-negative offset
- Throws:
- IOException
 
- 
readLongRead long value from channel starting at offset.- Parameters:
- offset- non-negative offset
- Returns:
- long
- Throws:
- IOException
 
- 
writeIntWrite integer value to channel starting at offset.- Parameters:
- value- value to write
- offset- non-negative offset
- Throws:
- IOException
 
- 
readIntRead integer value from channel starting at offset.- Parameters:
- offset- non-negative offset
- Returns:
- integer
- Throws:
- IOException
 
 
-