并发编程工具集——CountDownLatch和CyclicBarrier(上篇)(二十)

贯穿全文的主线业务逻辑:对账系统的处理逻辑是首先查询订单,然后查询派送单,之后对比订单和派送单,将差异写入差异库

利用并行优化对账系统

  1. 创建两个线程 T1 和 T2,并行执行查询未对账订单和查询派送单这两个操作。在主线程中执行对账操作 check() 和差异写入 save() 两个操作。
  2. 主线程需要等待线程 T1 和 T2 执行完才能执行 check() 和 save() 这两个操作,通过调用 T1.join() 和 T2.join() 来实现等待,当 T1 和 T2 线程退出时,调用 T1.join() 和 T2.join() 的主线程就会从阻塞态被唤醒,从而执行之后的 check() 和 save()。(每次都new有点儿浪费

 

用 CountDownLatch 实现线程等待 

  1. 上面操作问题:while 循环里面每次都会创建新的线程,而创建线程可是个耗时的操作。
  2. 在 while 循环里面,我们首先创建了一个 CountDownLatch,计数器的初始值等于 2,之后在查询未对账订单和查询派送单两条语句的后面对计数器执行减 1 操作,这个对计数器减 1 的操作是通过调用 latch.countDown(); 来实现的。在主线程中,我们通过调用 latch.await() 来实现对计数器等于 0 的等待。

  • 11
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值