juc的CountDownLatch用于实现一个任务的执行需要其他条件的满足后才能执行。
主要有一个构造器:CountDown(int count);//条件个数
两个方法:
countDown()//一个条件满足时进行减1操作
await()//所有条件满足前阻塞等待,不往下执行
代码举例:
package com.example.mybatisplus;
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.TimeUnit;
public class CountDownLatchTest {
public static void main(String[] args) {
CountDownLatch countDownLatch = new CountDownLatch(6);
System.out.println(Thread.currentThread().getName()+":开始执行6个任务");
for (int i = 0; i < 6; i++) {
int finalI = i;
Runnable r = () -> {
try {
TimeUnit.SECONDS.sleep(2);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName()+":执行第"+ finalI +"个任务");
countDownLatch.countDown();
};
new Thread(r,i+"号任务").start();
}
try {
countDownLatch.await();
System.out.println(Thread.currentThread().getName()+":所有任务执行完毕");
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
RedissonClient的CountDownLatch可以将分布式系统中的多个条件作为一个任务执行的条件,
主要有4个方法:
getCountDownLatch(String latchName)//门闩名
trySetCount(int count)////条件个数
countDown()//一个条件满足时进行减1操作
await()//所有条件满足前阻塞等待,不往下执行
代码举例:
/**
* 测试awaite()方法
*/
@GetMapping("/redisCountDownLatchTest")
public void redisCountDownLatchTest(){
RCountDownLatch latch = redissonClient.getCountDownLatch("latch");
latch.trySetCount(6);
System.out.println("等待6个任务执行");
try {
latch.await();
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("所有任务都执行完了");
}
/**
* 测试countDown()方法
*/
@GetMapping("/redisCountDownTest")
public void redisCountDownTest(){
RCountDownLatch latch = redissonClient.getCountDownLatch("latch");
latch.countDown();
System.out.println("执行了一个任务");
}