Java7并发编程--3.6、Exchanger并发任务间的数据交换

       Exchanger 是一个同步辅助类,用于两个并发线程之间在一个同步点进行数据交换。 

      关于Exchanger 的使用:

  • 两个线程必须使用同一个Exchanger对象,且只能是两个线程间的数据交换
  • exchanger.exchange(v)的时候,当前线程会被阻塞,直到另一个线程执行该方法,同时完成数据的交换,此处传入的参数类型是V,即要交换的数据结构(本例中为ArrayList<String>)
  • 类似这种数据交换的,生产者线程一定要先生产数据,再交换数据,消费者线程一定要先交换数据,再消费数据,否则会出现少消费数据的现象
场景事例描述:一对一的生产者和消费者,生产者每次生产5个商品,然后消费者把空的商品容器和生产者交换。




这里提一个有意思的地方,假如:我们把第9、10行的执行顺序调换下,让consumer在前,结果你发现还是先生产后消费。这个是为什么呢?
1. 从java内存模型角度来说,上面两行代码没有数据依赖性(在实际执行的时候他们的顺序不一定是谁先谁后) 
2. 原因就出现在exchanger.exchange(v)方法,就算是消费者先执行,仔细看代码,消费者会先执行exchanger.exchange(v)方法,如果之前没有线程执行该方法,那么消费者则会休眠等待生产者执行该方法。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值