天天看点

Java IO: 管道

原文链接 作者: jakob jenkov  译者: 李璟([email protected])

java io中的管道为运行在同一个jvm中的两个线程提供了通信的能力。所以管道也可以作为数据源以及目标媒介。

你不能利用管道与不同的jvm中的线程通信(不同的进程)。在概念上,java的管道不同于unix/linux系统中的管道。在unix/linux中,运行在不同地址空间的两个进程可以通过管道通信。在java中,通信的双方应该是运行在同一进程中的不同线程。

可以通过java io中的pipedoutputstream和pipedinputstream创建管道。一个pipedinputstream流应该和一个pipedoutputstream流相关联。一个线程通过pipedoutputstream写入的数据可以被另一个线程通过相关联的pipedinputstream读取出来。

这是一个如何将pipedinputstream和pipedoutputstream关联起来的简单例子:

Java IO: 管道

你也可以使用两个管道共有的connect()方法使之相关联。pipedinputstream和pipedoutputstream都拥有一个可以互相关联的connect()方法。

请记得,当使用两个相关联的管道流时,务必将它们分配给不同的线程。read()方法和write()方法调用时会导致流阻塞,这意味着如果你尝试在一个线程中同时进行读和写,可能会导致线程死锁。

除了管道之外,一个jvm中不同线程之间还有许多通信的方式。实际上,线程在大多数情况下会传递完整的对象信息而非原始的字节数据。但是,如果你需要在线程之间传递字节数据,java io的管道是一个不错的选择。 

上一篇: Java IO: 网络
下一篇: Java IO: 文件