管道流(PipedStream)可以用于不同线程间直接传送数据。
一个线程发送数据到输出管道,另一个线程从输入管道中读取数据。通过使用管道,实现不同线程间的通信,而无须借助于类似临时文件之类的东西。
package thread.communicate; import java.io.IOException; import java.io.PipedInputStream; import java.io.PipedOutputStream; /*2015-11-19*/ public class CommunicateWithPipedStream { public static void main(String[] args) { try { PipedOutputStream out = new PipedOutputStream(); DataWriter writer = new DataWriter(out); PipedInputStream in = new PipedInputStream(); DataReader reader = new DataReader(in); // out.connect(in); in.connect(out); new Thread(writer, "Writer").start(); new Thread(reader, "Reader").start(); } catch (Exception e) { e.printStackTrace(); } } } class DataWriter implements Runnable { private PipedOutputStream _out; public DataWriter(PipedOutputStream out) { super(); this._out = out; } @Override public void run() { write(); } public void write() { System.out.println(Thread.currentThread() + "Start write...."); try { for (int i = 0; i < 20; i++) { String outStr = "" + (i + 1); System.out.println(Thread.currentThread() + outStr); _out.write(outStr.getBytes()); } _out.close(); } catch (IOException e) { e.printStackTrace(); } } } class DataReader implements Runnable { private PipedInputStream _in; public DataReader(PipedInputStream in) { _in = in; } @Override public void run() { read(); } public void read() { try { System.out.println(Thread.currentThread() + "Start read...."); byte[] byteArray = new byte[20]; int readLength = _in.read(byteArray); while (readLength != -1) { String newData = new String(byteArray, 0, readLength); System.out.println(Thread.currentThread() + newData); readLength = _in.read(byteArray); } System.out.println(); _in.close(); } catch (Exception e) { e.printStackTrace(); } } }
输出:
Thread[Writer,5,main]Start write.... Thread[Writer,5,main]1 Thread[Reader,5,main]Start read.... Thread[Writer,5,main]2 Thread[Reader,5,main]1 Thread[Reader,5,main]2 Thread[Writer,5,main]3 Thread[Writer,5,main]4 Thread[Writer,5,main]5 Thread[Writer,5,main]6 Thread[Writer,5,main]7 Thread[Writer,5,main]8 Thread[Writer,5,main]9 Thread[Writer,5,main]10 Thread[Writer,5,main]11 Thread[Writer,5,main]12 Thread[Writer,5,main]13 Thread[Writer,5,main]14 Thread[Writer,5,main]15 Thread[Writer,5,main]16 Thread[Writer,5,main]17 Thread[Writer,5,main]18 Thread[Writer,5,main]19 Thread[Writer,5,main]20 Thread[Reader,5,main]34567891011121314151 Thread[Reader,5,main]617181920