CountDownLatch
- await(),进入等待的状态
- countDown(),计数器减一
应用场景
启动三个线程计算,需要对结果进行累加。
CyclicBarrier--栅栏
允许一组线程相互等待达到一个公共的障碍点,之后再继续执行
跟countDownLatch的区别
CountDownLatch
:一般用于某个线程等待若干个其他线程执行完任务之后,它才执行;不可重复使用CyclicBarrier
:一般用于一组线程互相等待至某个状态,然后这一组线程再同时执行;可重用的
Semaphore--信号量
控制开发数量接口限流
Exchanger
用于交换数据
它提供一个同步点,在这个同步点两个线程可以交换彼此的数据。这两个线程通过exchange方法交换数据, 如果第一个线程先执行exchange方法,它会一直等待第二个线程也执行exchange,当两个线程都到达同步点时,这两个线程就可以交换数据,将本线程生产出来的数据传递给对方。
因此使用Exchanger的重点是成对的线程使用exchange()方法,当有一对线程达到了同步点,就会进行交换数据。因此该工具类的线程对象是【成对】的。