java多线程管道通讯_java多线程之任务间管道通信 | 学步园

package com.eshroe.sweetop.concurrency;

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;

class Sender implements Runnable {

private Random rand = new Random(47);

private PipedWriter out = new PipedWriter();

public PipedWriter getPipedWriter() {

return out;

}

public void run() {

try {

while (true) {

for (char c = 'A'; c <= 'z'; c++) {

out.write(c);

TimeUnit.MILLISECONDS.sleep(rand.nextInt(500));

}

}

} catch (IOException e) {

System.out.println("Sender write exception");

} catch (InterruptedException e) {

System.out.println("Sender sleep interrupted");

}

}

}

class Receiver implements Runnable {

private PipedReader in;

public Receiver(Sender sender) throws IOException {

in = new PipedReader(sender.getPipedWriter());

}

public void run() {

try {

while (true) {

System.out.println("Read: " + (char) in.read());

}

} catch (IOException e) {

System.out.println("Receiver read exception");

}

}

}

public class PipedIO {

public static void main(String[] args) throws Exception {

Sender sender=new Sender();

Receiver receiver=new Receiver(sender);

ExecutorService exec=Executors.newCachedThreadPool();

exec.execute(sender);

exec.execute(receiver);

TimeUnit.SECONDS.sleep(15);

exec.shutdownNow();

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值