加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

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

发布时间:2020-12-14 16:29:07 所属栏目:Java 来源:网络整理
导读:我想编写一个同时写入多个文件的程序;认为通过使用非阻塞模式可以使用一个线程.但是FileChannel不支持非阻塞模式.有人知道为什么吗 解决方法 UNIX不支持文件的非阻塞I / O,请参见 Non-blocking I/O with regular files.由于Java应该(至少尝试)在所有平台上提
我想编写一个同时写入多个文件的程序;认为通过使用非阻塞模式可以使用一个线程.但是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上读取并且目前没有数据可用,那么线程会阻塞…(通常),直到数据变得可用.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读