贯穿全文的主线业务逻辑:对账系统的处理逻辑是首先查询订单,然后查询派送单,之后对比订单和派送单,将差异写入差异库
利用并行优化对账系统
- 创建两个线程 T1 和 T2,并行执行查询未对账订单和查询派送单这两个操作。在主线程中执行对账操作 check() 和差异写入 save() 两个操作。
- 主线程需要等待线程 T1 和 T2 执行完才能执行 check() 和 save() 这两个操作,通过调用 T1.join() 和 T2.join() 来实现等待,当 T1 和 T2 线程退出时,调用 T1.join() 和 T2.join() 的主线程就会从阻塞态被唤醒,从而执行之后的 check() 和 save()。(每次都new有点儿浪费)
用 CountDownLatch 实现线程等待
- 上面操作问题:while 循环里面每次都会创建新的线程,而创建线程可是个耗时的操作。
- 在 while 循环里面,我们首先创建了一个 CountDownLatch,计数器的初始值等于 2,之后在查询未对账订单和查询派送单两条语句的后面对计数器执行减 1 操作,这个对计数器减 1 的操作是通过调用 latch.countDown(); 来实现的。在主线程中,我们通过调用 latch.await() 来实现对计数器等于 0 的等待。