• java 多线程 29 :多线程组件之 Exchanger


    Exchanger

    Exchanger,从名字上理解就是交换。Exchanger用于在两个线程之间进行数据交换,注意也只能在两个线程之间进行数据交换。线程会阻塞在Exchanger的exchange方法上,直到另外一个线程也到了同一个Exchanger的exchange方法时,二者进行数据交换,然后两个线程继续执行自身相关的代码。

    Exchanger只有一个exchange方法,用于交换数据。看一下例子:

    public static class ExchangerThread extends Thread
    {
        private String str;
        private Exchanger<String> exchanger;
        private int sleepSecond;
        
        public ExchangerThread(String str, Exchanger<String> exchanger, int sleepSecond)
        {
            this.str = str;
            this.exchanger = exchanger;
            this.sleepSecond = sleepSecond;
        }
            
        public void run()
        {
            try
            {
                System.out.println(this.getName() + "启动, 原数据为" + str + ", 时间为" + System.currentTimeMillis());
                Thread.sleep(sleepSecond * 1000);
                str = exchanger.exchange(str);
                System.out.println(this.getName() + "交换了数据, 交换后的数据为" + str + ", 时间为" + System.currentTimeMillis());
            } 
            catch (InterruptedException e)
            {
                e.printStackTrace();
            }
        }
    }
        
    public static void main(String[] args)
    {
        Exchanger<String> exchanger = new Exchanger<String>();
        ExchangerThread et0 = new ExchangerThread("111", exchanger, 3);
        ExchangerThread et1 = new ExchangerThread("222", exchanger, 2);
        et0.start();
        et1.start();
    }

    看一下运行结果:

    Thread-0启动, 原数据为111, 时间为1444560972303
    Thread-1启动, 原数据为222, 时间为1444560972303
    Thread-0交换了数据, 交换后的数据为222, 时间为1444560975303
    Thread-1交换了数据, 交换后的数据为111, 时间为1444560975303

    看到两个线程交换了数据,由于一个线程睡2秒、一个线程睡3秒,既然要交换数据,肯定是睡2秒的要等待睡3秒的,所以看到时间差是3000ms即3s。


    ps:这里感觉是,一个线程需要另一个线程跟他同步的时候  会用到 ,也可用作管道相互通知,先mark

  • 相关阅读:
    Scala进阶之路-idea下进行spark编程
    Scala进阶之路-Spark本地模式搭建
    Scala进阶之路-Scala高级语法之隐式(implicit)详解
    Scala进阶之路-Spark底层通信小案例
    Scala进阶之路-并发编程模型Akka入门篇
    Scala进阶之路-统计商家id的标签数以及TopN示例案例分析
    Scala进阶之路-Scala中的泛型介绍
    Scala进阶之路-尾递归优化
    Scala进阶之路-Scala特征类与unapply反向抽取
    Java基础-爬虫实战之爬去校花网网站内容
  • 原文地址:https://www.cnblogs.com/signheart/p/6098ec11e9ea8accba466054d716f65d.html
Copyright © 2020-2023  润新知