博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Exchanger类详解
阅读量:6497 次
发布时间:2019-06-24

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

  Exchanger并发辅助类,允许在并发任务之间交换数据。具体来说Exchanger类在两个线程之间定义同步点。当两个线程到达同步点时,它们交换数据结构。需要注意的是Exchanger类只能同步两个线程。

  内存一致性效果:对于通过Exchanger成功交换对象的每对线程,每个线程中在exchanger()之前的操作 happen-before从另一线程中相应的exchanger()返回的后续操作。

下面用一对一的生产者-消费者例子进行说明。

  生产者代码如下:

public class Producer implements Runnable {    private List
buffer; private Exchanger
> exchanger; public Producer(List
buffer, Exchanger
> exchanger) { this.buffer = buffer; this.exchanger = exchanger; } @Override public void run() { int cycle=1; for (int i=0; i<10; i++) { System.out.println("Producer:Cycle "+cycle); for (int j = 1; j <=10; j++) { String msg="Event "+(i*10+j); System.out.println("Producer: "+msg); buffer.add(msg); } try { buffer=exchanger.exchange(buffer);//和消费者交换数据结构 } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("Producer size: "+buffer.size()); cycle++; } }}

  消费者代码:

public class Consumer implements Runnable {    private List
buffer; private Exchanger
> exchanger; public Consumer(List
buffer, Exchanger
> exchanger) { this.buffer = buffer; this.exchanger = exchanger; } @Override public void run() { int cycle=1; for (int i=0; i<=9; i++) { System.out.println("Consumer: Cycle "+cycle); try { buffer=exchanger.exchange(buffer);//he生产者交换数据结构 } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("Consumer size: "+buffer.size()); for (int j = 1; j <=10; j++) { String msg=buffer.get(0); System.out.println("Consumer: "+msg); buffer.remove(0); } cycle++; } }}

  运行:

public class Core {    public static void main(String[] args) {        List
buffer1=new ArrayList
(); List
buffer2=new ArrayList
(); Exchanger
> exchanger=new Exchanger
>(); Producer producer=new Producer(buffer1, exchanger); Consumer consumer=new Consumer(buffer2, exchanger); Thread thread1=new Thread(producer); Thread thread2=new Thread(consumer); thread1.start(); thread2.start(); }}

转载于:https://www.cnblogs.com/wxgblogs/p/5431249.html

你可能感兴趣的文章
菜鸟谈谈C#中的构造函数和析构函数
查看>>
2014-4-21
查看>>
【转】Python多进程编程
查看>>
旁注攻击介
查看>>
Android之Service与IntentService的比较
查看>>
Single Number
查看>>
Struts2部分
查看>>
2014-8-4阿里电话面试
查看>>
这些小工具让你的Android 开发更高效
查看>>
T-SQL注意事项(1)——SET NOCOUNT ON的去与留
查看>>
Spring4新的javaConfig注解
查看>>
移动端的交互设计软件JustinMind
查看>>
DotNetCore 定时服务 HangFire
查看>>
Centos7安装Git
查看>>
Struts2学习笔记(九)——数据校验
查看>>
web系统压力测试
查看>>
我爱我家-北京-mysql
查看>>
win32 进程崩溃时禁止弹出错误对话框
查看>>
FZU 2110 Star 数学
查看>>
POJ 2886Who Gets the Most Candies?(线段树)
查看>>