CountDownLatch简单例子

public class CountDownLatchDemo {
	public static void main(String[] args) {
		CountDownLatch countDownLatch = new CountDownLatch(2);

		new Thread(new Runnable() {

			@Override
			public void run() {
				// TODO Auto-generated method stub
				try {
					Thread.sleep((long) (Math.random() * 30000));
				} catch (InterruptedException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}
				System.out.println("1进来了");
				countDownLatch.countDown();
			}
		}).start();
		new Thread(new Runnable() {

			@Override
			public void run() {
				// TODO Auto-generated method stub
				try {
					Thread.sleep((long) (Math.random() * 300));
				} catch (InterruptedException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}
				System.out.println("2进来了");
				countDownLatch.countDown();
			}
		}).start();
		try {
			countDownLatch.await();
		} catch (InterruptedException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		System.out.println("结束了");
	}

CountDownLatch 只有当计数为0 的时候才会放行, 所以不管上面两个线程,只有当两个线程都完成的时候才会输出最后一句话“结束了”,至于为什么CountDownLatch 是线程安全的。 我点进去看了, countDownLatch 里面有个静态内部类Sync 继承了Aqs,执行CountDown()的时候走父类release, 然后走sync 的tryRelease 。 至于静态内部类为什么是线程安全的?找资料中

转载于:https://my.oschina.net/u/4042146/blog/2980100

CountDownLatch是Java并发包中的一个工具类,它可以让一个或多个线程等待其他线程完成操作后再继续执行,通常用于协调多个线程之间的同步操作。 CountDownLatch的使用步骤如下: 1. 创建CountDownLatch对象,指定计数器的初始值,表示需要等待的线程个数。 2. 在需要等待的线程中,调用CountDownLatch的await()方法,等待计数器为0。 3. 在需要等待的线程执行完任务后,调用CountDownLatchcountDown()方法,将计数器减1。 4. 当计数器减为0时,所有等待的线程将被唤醒,继续执行。 下面是CountDownLatch的一个简单例子: ```java import java.util.concurrent.CountDownLatch; public class CountDownLatchDemo { public static void main(String[] args) throws InterruptedException { int nThreads = 5; CountDownLatch latch = new CountDownLatch(nThreads); for (int i = 0; i < nThreads; i++) { Thread t = new Thread(() -> { try { // 模拟每个线程执行一段耗时的任务 Thread.sleep((long) (Math.random() * 1000)); System.out.println(Thread.currentThread().getName() + " finished"); } catch (InterruptedException e) { e.printStackTrace(); } finally { // 执行完任务后,计数器减1 latch.countDown(); } }); t.start(); } // 等待所有线程执行完毕 latch.await(); System.out.println("All threads finished"); } } ``` 上述示例中,我们创建了5个线程,每个线程执行一段随机时长的任务,并在最后调用countDown()方法将计数器减1。主线程通过await()方法等待所有线程执行完毕后,输出"All threads finished"表示程序执行结束。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值