org.apache.lucene.store
Class NIOFSDirectory
java.lang.Object
org.apache.lucene.store.Directory
org.apache.lucene.store.FSDirectory
org.apache.lucene.store.NIOFSDirectory
- All Implemented Interfaces:
- Closeable
public class NIOFSDirectory
- extends FSDirectory
An FSDirectory
implementation that uses java.nio's FileChannel's
positional read, which allows multiple threads to read from the same file
without synchronizing.
This class only uses FileChannel when reading; writing is achieved with
FSDirectory.FSIndexOutput
.
NOTE: NIOFSDirectory is not recommended on Windows because of a bug in
how FileChannel.read is implemented in Sun's JRE. Inside of the
implementation the position is apparently synchronized. See here
for details.
NOTE: Accessing this class either directly or
indirectly from a thread while it's interrupted can close the
underlying file descriptor immediately if at the same time the thread is
blocked on IO. The file descriptor will remain closed and subsequent access
to NIOFSDirectory
will throw a ClosedChannelException
. If
your application uses either Thread.interrupt()
or
Future.cancel(boolean)
you should use SimpleFSDirectory
in
favor of NIOFSDirectory
.
Methods inherited from class org.apache.lucene.store.FSDirectory |
close, createOutput, deleteFile, ensureCanWrite, fileExists, fileLength, fileModified, fileModified, fsync, getDirectory, getFile, getLockID, getReadChunkSize, listAll, listAll, onIndexOutputClosed, open, open, openInput, setLockFactory, setReadChunkSize, sync, sync, toString, touchFile |
NIOFSDirectory
public NIOFSDirectory(File path,
LockFactory lockFactory)
throws IOException
- Create a new NIOFSDirectory for the named location.
- Parameters:
path
- the path of the directorylockFactory
- the lock factory to use, or null for the default
(NativeFSLockFactory
);
- Throws:
IOException
NIOFSDirectory
public NIOFSDirectory(File path)
throws IOException
- Create a new NIOFSDirectory for the named location and
NativeFSLockFactory
.
- Parameters:
path
- the path of the directory
- Throws:
IOException
openInput
public IndexInput openInput(String name,
int bufferSize)
throws IOException
- Creates an IndexInput for the file with the given name.
- Overrides:
openInput
in class Directory
- Throws:
IOException