zoukankan      html  css  js  c++  java
  • 多线程通讯之管道

    管道流是JAVA中线程通讯的常用方式之一,基本流程如下:

    1)创建管道输出流PipedOutputStream pos和管道输入流PipedInputStream pis

    2)将pos和pis匹配,pos.connect(pis);

    3)将pos赋给信息输入线程,pis赋给信息获取线程,就可以实现线程间的通讯了

    import java.io.IOException;  
    import java.io.PipedInputStream;  
    import java.io.PipedOutputStream;  
      
    public class testPipeConnection {  
      
        public static void main(String[] args) {  
            /** 
             * 创建管道输出流 
             */  
            PipedOutputStream pos = new PipedOutputStream();  
            /** 
             * 创建管道输入流 
             */  
            PipedInputStream pis = new PipedInputStream();  
            try {  
                /** 
                 * 将管道输入流与输出流连接 此过程也可通过重载的构造函数来实现 
                 */  
                pos.connect(pis);  
            } catch (IOException e) {  
                e.printStackTrace();  
            }  
            /** 
             * 创建生产者线程 
             */  
            Producer p = new Producer(pos);  
            /** 
             * 创建消费者线程 
             */  
            Consumer1 c1 = new Consumer1(pis);  
            /** 
             * 启动线程 
             */  
            p.start();  
            c1.start();  
        }  
    }  
      
    /** 
     * 生产者线程(与一个管道输入流相关联) 
     *  
     */  
    class Producer extends Thread {  
        private PipedOutputStream pos;  
      
        public Producer(PipedOutputStream pos) {  
            this.pos = pos;  
        }  
      
        public void run() {  
            int i = 0;  
            try {  
                while(true)  
                {  
                this.sleep(3000);  
                pos.write(i);  
                i++;  
                }  
            } catch (Exception e) {  
                e.printStackTrace();  
            }  
        }  
    }  
      
    /** 
     * 消费者线程(与一个管道输入流相关联) 
     *  
     */  
    class Consumer1 extends Thread {  
        private PipedInputStream pis;  
      
        public Consumer1(PipedInputStream pis) {  
            this.pis = pis;  
        }  
      
        public void run() {  
            try {  
                while(true)  
                {  
                System.out.println("consumer1:"+pis.read());  
                }  
            } catch (IOException e) {  
                e.printStackTrace();  
            }  
        }  
    }  

    程序启动后,就可以看到producer线程往consumer1线程发送数据

    管道流虽然使用起来方便,但是也有一些缺点

    1)管道流只能在两个线程之间传递数据

    线程consumer1和consumer2同时从pis中read数据,当线程producer往管道流中写入一段数据后,每一个时刻只有一个线程能获取到数据,并不是两个线程都能获取到producer发送来的数据,因此一个管道流只能用于两个线程间的通讯。不仅仅是管道流,其他IO方式都是一对一传输。

    2)管道流只能实现单向发送,如果要两个线程之间互通讯,则需要两个管道流

     可以看到上面的例子中,线程producer通过管道流向线程consumer发送数据,如果线程consumer想给线程producer发送数据,则需要新建另一个管道流pos1和pis1,将pos1赋给consumer1,将pis1赋给producer,具体例子本文不再多说。

  • 相关阅读:
    wireshark如何抓取本机包
    模拟post请求方法
    Spring Boot中使用RabbitMQ
    Dubbo注册中心的四种配置方式详解
    spring扩展点之三:Spring 的监听事件 ApplicationListener 和 ApplicationEvent 用法,在spring启动后做些事情
    zookeeper 大量连接断开重连原因排查
    分布式一致性协议之:Gossip(八卦)算法
    MongoDB分析工具之一:explain()语句分析工具
    MongoDB分析工具之二:MongoDB分析器Profile
    MySQL安装
  • 原文地址:https://www.cnblogs.com/fengyan20150508/p/7846563.html
Copyright © 2011-2022 走看看