博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java:多线程,Exchanger同步器
阅读量:6434 次
发布时间:2019-06-23

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

1. 背景

类java.util.concurrent.Exchanger提供了一个同步点,在这个同步点,一对线程可以交换数据。每个线程通过exchange()方法的入口提供数据给他的伙伴线程,并接收他的伙伴线程提供的数据,并返回。

当在运行不对称的活动时很有用。比如说,一个线程向buffer中填充数据,另一个线程从buffer中消费数据;这些线程可以用Exchange来交换数据。这个交换对于两个线程来说都是安全的。

2. 示范代码

package com.clzhang.sample.thread;import java.util.*;import java.util.concurrent.Exchanger;public class SyncExchanger {    private static final Exchanger exchanger = new Exchanger();    class DataProducer implements Runnable {        private List list = new ArrayList();        @Override        public void run() {            for (int i = 0; i < 5; i++) {                System.out.println("生产了一个数据,耗时1秒");                list.add(new Date());                try {                    Thread.sleep(1000);                } catch (InterruptedException e) {                    e.printStackTrace();                }            }            try {                list = (List) exchanger.exchange(list);            } catch (InterruptedException e) {                e.printStackTrace();            }            for (Iterator iterator = list.iterator(); iterator.hasNext();) {                System.out.println("Producer " + iterator.next());            }        }    }    class DataConsumer implements Runnable {        private List list = new ArrayList();        @Override        public void run() {            for (int i = 0; i < 5; i++) {                list.add("这是一个收条。");            }            try {                list = (List) exchanger.exchange(list);            } catch (InterruptedException e) {                e.printStackTrace();            }            for (Iterator iterator = list.iterator(); iterator.hasNext();) {                Date d = (Date) iterator.next();                System.out.println("Consumer: " + d);            }        }    }    public static void main(String[] args) {        SyncExchanger ins = new SyncExchanger();        new Thread(ins.new DataProducer()).start();        new Thread(ins.new DataConsumer()).start();    }}

输出

生产了一个数据,耗时1秒
生产了一个数据,耗时1秒
生产了一个数据,耗时1秒
生产了一个数据,耗时1秒
生产了一个数据,耗时1秒
Producer 这是一个收条。
Producer 这是一个收条。
Producer 这是一个收条。
Producer 这是一个收条。
Producer 这是一个收条。
Consumer: Thu Sep 12 17:21:39 CST 2013
Consumer: Thu Sep 12 17:21:40 CST 2013
Consumer: Thu Sep 12 17:21:41 CST 2013
Consumer: Thu Sep 12 17:21:42 CST 2013
Consumer: Thu Sep 12 17:21:43 CST 2013

转载地址:http://npqga.baihongyu.com/

你可能感兴趣的文章
js判断对象的类型的四种方式
查看>>
RPC框架的可靠性设计
查看>>
使用自选择创建团队
查看>>
基准测试(Benchmarks)不必消亡
查看>>
ceph 常用命令记录(完善中...)
查看>>
C# 7.3新特性一览
查看>>
用Chrome开发者工具调试一切
查看>>
简易mvvm库的设计实现
查看>>
AppDynamics把业务交易跟踪扩展到SAP环境
查看>>
[Three.js]Three.js中文文档-自定义混合方程常数
查看>>
Kafka 处理器客户端介绍
查看>>
通过分析这段代码的进化历程,或许能够加深您对JavaScript的作用域的理解
查看>>
创建对象(一):创建与继承
查看>>
深入浅出vue1.0:Vue 实例
查看>>
XML 实体扩展攻击
查看>>
浅谈 OneAPM 在 express 项目中的实践
查看>>
kubernetes节点选择器
查看>>
Sublime Text 3初体验
查看>>
快速排序&归并排序
查看>>
将字符串转换成二维码
查看>>