博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
java高级---->Thread之Exchanger的使用
阅读量:4577 次
发布时间:2019-06-08

本文共 1790 字,大约阅读时间需要 5 分钟。

  Exchanger可以在两个线程之间交换数据,只能是2个线程,他不支持更多的线程之间互换数据。今天我们就通过实例来学习一下Exchanger的用法。

 

Exchanger的简单实例

  Exchanger是在两个任务之间交换对象的栅栏,当这些任务进入栅栏时,它们各自拥有一个对象。当他们离开时,它们都拥有之前由对象持有的对象。它典型的应用场景是:一个任务在创建对象,这些对象的生产代价很高昂,而另一个任务在消费这些对象。通过这种方式,可以有更多的对象在被创建的同时被消费。

一、Exchanger的简单使用

package com.linux.huhx.concurreny;import java.util.concurrent.Exchanger;import java.util.concurrent.ExecutorService;import java.util.concurrent.Executors;public class ExchangerTest {    public static void main(String[] args) {        ExecutorService executor = Executors.newCachedThreadPool();        final Exchanger exchanger = new Exchanger();        executor.execute(new Runnable() {            String data1 = "Ling";            @Override            public void run() {                doExchangeWork(data1, exchanger);            }        });        executor.execute(new Runnable() {            String data1 = "huhx";            @Override            public void run() {                doExchangeWork(data1, exchanger);            }        });        executor.shutdown();    }    private static void doExchangeWork(String data1, Exchanger exchanger) {        try {            System.out.println(Thread.currentThread().getName() + "正在把数据 " + data1 + " 交换出去");            Thread.sleep((long) (Math.random() * 1000));            String data2 = (String) exchanger.exchange(data1);            System.out.println(Thread.currentThread().getName() + "交换数据 到  " + data2);        } catch (InterruptedException e) {            e.printStackTrace();        }    }}

运行结果如下:不固定

pool-1-thread-1正在把数据 Ling 交换出去pool-1-thread-2正在把数据 huhx 交换出去pool-1-thread-2交换数据 到  Lingpool-1-thread-1交换数据 到  huhx

当线程A调用Exchange对象的exchange()方法后,他会陷入阻塞状态,直到线程B也调用了exchange()方法,然后以线程安全的方式交换数据,之后线程A和B继续运行。

 

友情链接

 

转载于:https://www.cnblogs.com/huhx/p/baseusejavaExchanger.html

你可能感兴趣的文章
linux清理Java环境
查看>>
如何更改webstrom的默认端口63342
查看>>
最短路计数
查看>>
SharedPreferences
查看>>
Android性能优化方法(六)
查看>>
yii2.0 报错Cookievalidationkey Must Be Configured With A Secret Key
查看>>
JQ在线引用地址
查看>>
TCP协议
查看>>
高级IO-锁与进程和文件
查看>>
对象在内存中的布局-对象的创建
查看>>
FZU 1077 铁皮容器 【枚举/二分】
查看>>
uva 11795 Mega Man's Mission(动态规划-状态压缩DP)
查看>>
MATLAB实现曲线拟合
查看>>
html总结
查看>>
WPF RichTextBox,关键字搜索,样式改变,超链接替换,图文混排
查看>>
gc日志分析
查看>>
数据结构--栈的思想与数组实现
查看>>
javascript的构造函数和原型
查看>>
ES数据迁移之elasticdump
查看>>
详解C#break ,continue, return
查看>>