Java IO: 并发IO

Posted 耳东陈

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java IO: 并发IO相关的知识,希望对你有一定的参考价值。

原文链接 作者: Jakob Jenkov 译者: 李璟

有时候你可能需要并发地处理输入和输出。换句话说,你可能有超过一个线程处理输入和产生输出。比如,你有一个程序需要处理磁盘上的大量文件,这个任务可以通过并发操作提高性能。又比如,你有一个web服务器或者聊天服务器,接收许多连接和请求,这些任务都可以通过并发获得性能的提升。

 

如果你需要并发处理IO,这里有几个问题可能需要注意一下:

在同一时刻不能有多个线程同时从InputStream或者Reader中读取数据,也不能同时往OutputStream或者Writer里写数据。你没有办法保证每个线程读取多少数据,以及多个线程写数据时的顺序。

如果线程之间能够保证操作的顺序,它们可以使用同一个stream、reader、writer。比如,你有一个线程判断当前的输入流来自哪种类型的请求,然后将流数据传递给其他合适的线程做后续处理。当有序存取流、reader、writer时,这种做法是可行的。请注意,在线程之间传递流数据的代码应当是同步的。

注意:在Java NIO中,你可以让一个线程读写多个“channel”。比如,你有很多网络连接处于开启状态,但是每个连接中都只有少量数据,类似于聊天服务器,可以让一个线程监视多个频道(连接)。Java NIO是另一个话题了,会后续教程中介绍。

原创文章,转载请注明: 转载自并发编程网 – ifeve.com本文链接地址: Java IO: 并发IO

以上是关于Java IO: 并发IO的主要内容,如果未能解决你的问题,请参考以下文章

java之IO

Java IO:面向流同步堵塞式IO(BIO)

Java之IO文件系统

Java IO流之拷贝(复制)文件

Java IO编程全解——伪异步IO编程

Java IO:SocketChannel和Selector在ZooKeeper中应用