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

前端之家收集整理的这篇文章主要介绍了为什么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上读取并且目前没有数据可用,那么线程会阻塞…(通常),直到数据变得可用.

原文链接:https://www.f2er.com/java/125209.html

猜你在找的Java相关文章