为什么Java中的FileChannel不是非阻塞的?

我想编写一个同时写入多个文件的程序;认为通过使用非阻塞模式可以使用一个线程.但是FileChannel不支持非阻塞模式.有人知道为什么吗

解决方法

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上读取并且目前没有数据可用,那么线程会阻塞…(通常),直到数据变得可用.

相关文章

最近看了一下学习资料,感觉进制转换其实还是挺有意思的,尤...
/*HashSet 基本操作 * --set:元素是无序的,存入和取出顺序不...
/*list 基本操作 * * List a=new List(); * 增 * a.add(inde...
/* * 内部类 * */ 1 class OutClass{ 2 //定义外部类的成员变...
集合的操作Iterator、Collection、Set和HashSet关系Iterator...
接口中常量的修饰关键字:public,static,final(常量)函数...