• 多线程通讯之管道


    管道流是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,具体例子本文不再多说。

  • 相关阅读:
    CEF(Chromium Embedded Framework)使用说明书
    2.CEF常用接口类拦截请求回调函数
    CEF(Chromium Embedded Framework和JavaScript交互相互调用函数和设置数据
    CefV8Value类实现定JavaScript数据类型、数组、对象
    CEF(Chromium Embedded Framework)进程间通讯
    scikit_learn分类器详解
    3.Scikit-Learn实现完整的机器学习项目
    TCP/IP_网络基础知识
    零基础学习python_爬虫(53课)
    安全测试8_Web安全实战3(命令注入)
  • 原文地址:https://www.cnblogs.com/fengyan20150508/p/7846563.html
Copyright © 2020-2023  润新知