博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java IO: 管道
阅读量:6311 次
发布时间:2019-06-22

本文共 842 字,大约阅读时间需要 2 分钟。

 作者: Jakob Jenkov  译者: 李璟(jlee381344197@gmail.com)

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

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

 

通过Java IO创建管道

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

Java IO管道示例

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

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

管道和线程

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

管道的替代

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

原创文章,转载请注明: 转载自本文链接地址: 

 

转载于:https://www.cnblogs.com/dassmeta/p/5323887.html

你可能感兴趣的文章
ios10 no route to host
查看>>
poj 1659 Frogs' Neighborhood 度序列可图化 贪心
查看>>
小组聚餐小记
查看>>
机器学习笔记十三:Ensemble思想(上)
查看>>
BZOJ 3460 Jc的宿舍
查看>>
ubuntu 工作区切换快捷键设置
查看>>
Django virtualenv Apache2 mod_wsgi
查看>>
推荐五个最佳编程字体
查看>>
在CentOS6上 ArcSDE for Oracle11gR2安装与配置
查看>>
ASP.Net生成静态HTML页
查看>>
error rpm cannot be installed
查看>>
SQL Server2008卸载
查看>>
在Eclipse中安装和使用TFS插件 (转)
查看>>
数据结构 【实验7 二叉树基本操作】
查看>>
Andriod中绘(画)图----Canvas的使用具体解释
查看>>
Lucene基础学习笔记
查看>>
使用Monkeyrunner进行Android自动化的总结
查看>>
Linux SSH登录慢案例分析
查看>>
典型的垃圾收集器
查看>>
输入数字动态创建行(二)
查看>>