CyclicBarrier 实现线程同步
- 在下面的代码中,我们首先创建了一个计数器初始值为 2 的 CyclicBarrier,创建 CyclicBarrier 的时候,传入一个回调函数,当计数器减到 0 的时候,会调用这个回调函数。
- 线程 T1 负责查询订单,当查出一条时,调用 barrier.await() 来将计数器减 1,同时等待计数器变成 0;
- 线程 T2 负责查询派送单,当查出一条时,也调用 barrier.await() 来将计数器减 1,同时等待计数器变成 0;当 T1 和 T2 都调用 barrier.await() 的时候,计数器会减到 0,此时 T1 和 T2 就可以执行下一条语句了,同时会调用 barrier 的回调函数来执行对账操作。
- CyclicBarrier 的计数器有自动重置的功能,当减到 0 的时候,会自动重置设置的初始值。