- 通过输入/输出在线程间进行通信通常很有用。在Java输入/输出类库中的对应物就是PipedWriter类。(允许任务向管道写)和PipedReader类(允许不同任务从同一个管道中读取)。
import java.io.IOException;
import java.io.PipedReader;
import java.io.PipedWriter;
import java.util.Random;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.TimeUnit;
/**
* Created by Panda on 2018/6/6.
*/
class Sender implements Runnable{
private Random random = new Random(47);
private PipedWriter out = new PipedWriter();
public PipedWriter getPipedWriter(){return out;}
@Override
public void run() {
try{
while (true)
for(char c='A';c<'z';c++){
out.write(c);
TimeUnit.MILLISECONDS.sleep(random.nextInt(500));
}
}catch (IOException e){
System.out.println(e+ " Sender write exception");
}catch (InterruptedException e){
System.out.println(e+" Sender sleep interrupted");
}
}
}
class Receiver implements Runnable{
private PipedReader in;
public Receiver(Sender sender )throws IOException{
in=new PipedReader(sender.getPipedWriter());
}
@Override
public void run() {
try{
while (true){
System.out.println("Read: "+(char)in.read()+",");
}
}catch (IOException e){
System.out.println(e+" Receiver read exception");
}
}
}
public class PipedIO {
public static void main(String[] args)throws Exception {
Sender sender = new Sender();
Receiver receiver = new Receiver(sender);
ExecutorService executorService = Executors.newCachedThreadPool();
executorService.execute(sender);
executorService.execute(receiver);
TimeUnit.SECONDS.sleep(4);
executorService.shutdownNow();
}
}