解决方法
UNIX不支持文件的非阻塞I / O,请参见
Non-blocking I/O with regular files.由于Java应该(至少尝试)在所有平台上提供相同的行为,所以FileChannel不会实现SelectableChannel.
然而,Java 7将包括一个支持异步文件I / O的新AsynchronousFileChannel
类,这是不阻塞I / O的不同机制.其中一个实现WindowsAsynchronousFileChannelImpl
受益于Windows上的非阻塞I / O API(参见Asynchronous I/O in Windows).
在此期间,您可以使用多个线程来实现相同的效果.但是这已经在SimpleAsynchronousFileChannelImpl
中实现,它可以在所有操作系统中移植.
通常只有插座和管道通过select()机制真正支持非阻塞I / O.
@所以评论:
“AsynchronousFileChannel supports asynchronous I/O rather then non-blocking.”
在我看来,异步I / O(使用例如Future或CompletionHandler)是一种非阻塞I / O的形式.
>它不阻止在通道上执行read(…)调用的线程.
>您可以使用Future.isDone()来避免稍后阻塞.
(当然,使用选择器的I / O也可以是异步的,具体取决于您如何使用API.)
相比之下,如果您在FileChannel上读取并且目前没有数据可用,那么线程会阻塞…(通常),直到数据变得可用.