使用管道数据流传送数据

 
Java I/O系统是建立在数据流概念之上的,在UNIX操作系统中有一个类似的概念很流行,那就是管道,它具有将一个程序的输出当作另一个程序的输入的能力。



Java为这种管道概念提供了PipedInputStream和PipedOutputStream类。将这两者结合在一起,它们允许一个Java组件输出数据到输出流,而另一个组件将这个输出流当作输入流来读取。

举个例子可以说明,比如一个用来记录应用程序日志信息的组件和一个用来显示流数据动态报表的组件。通过给日志记录组件提供PipedOutputStream,给报表组件提供相应的PipedInputStream,这两个组件就不用知道对方的情况而可以相互通信。

最简单的情况下,代码段如下所示:
  1. importjava.io.*; 
  2. public class Foo { 
  3. static public void main(String[] args) throwsIOException { 
  4. PipedOutputStream pout = newPipedOutputStream(); 
  5. PipedInputStream= new PipedInputStream(pout); 
  6. for(int i=0; i 〈 100; i++) { 
  7. pout.write((byte)i ); 
  8. pout.close(); 
  9. int j=0
  10. while( (j = pin.read()) != -1
  11. System.err.println(j); 
  12. pin.close(); 

上面的代码中,一定要记得调用close()以关闭输出流"pout",否则第二轮循环永远也不会结束。

这个粗泛的例子并不是正常的可用的代码。随着第一轮循环数量越来越大,PipedOutputStream中的缓冲将会用尽,从而出现问题,比如它在等待某些程序从流里面删除数据时会导致线程死锁。

这就是为什么管道流的Javadoc中声明了PipedInputStream和PipedOutputStream必须用在多线程环境里面的原因。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值