Java管道通信

本文介绍了Java中的管道通信,通过《Thinking in Java》中的实例展示了如何使用PipedWriter和PipedReader实现任务间的输入输出通信。管道作为一个缓冲区,连接生产者和消费者的任务,确保数据的正确传递。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在学习并发编程的时候,对于任务间的通信有了一些新的认识,之前没有接触过管道通信,但在《Thinking in Java》这本书中得到了很好的补充学习。接下来我将结合一个IO实例来演示任务间使用管道进行输入输出的通信,相信你会跟我一样对管道有一个新的认识。
一、管道的认识
在java的类库中有2个管道类: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;

/**
 * @author wangjie
 * @version 2018/11/21
 * 任务间使用管道进行输入输出
 */
class Sender implements Runnable{
    private Random random = 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);
                    //随机休眠500以内毫秒
                    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 interrupt");
        }
    }
}

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(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 exec = Executors.newCachedThreadPool();
        exec.execute(sender);
        exec.execute(receiver);
        //休眠4秒钟后中断
        TimeUnit.SECONDS.sleep(4);
        exec.shutdownNow();

    }
}

看看结果:
在这里插入图片描述
三、分析
Sender和Receiver分别代表了2个需要互相通信的任务(相当于生产者和消费者的角色),Sender 简历一个单独的PipedWriter对象,将信息写入到管道当中,而Receiver建立的PipedReader对象必须绑定到与Sender相关联的管道中,才能保证正确读取到数据。
详细内容请参考《Thinking in Java》,pageId:717
******************************************************************************

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值