共享锁CountDownLatch练习

CountDownLatch基本概念

  • 共享锁,用于在线程之间进行操作同步的工具类。

共享锁就是在同一时刻允许多个线程持有的锁。获得共享锁的线程只能读取临界区的数据,不能修改临界区的数据。

  • CountDownLatch可以指定一个计数值,在并发环境下由线程进行减一操作,当计数值变为0之后,被await方法阻塞的线程将会唤醒。

代码练习

public class Person implements Runnable{
    private final CountDownLatch doneSignal;
    private final int i;

    public Person(CountDownLatch doneSignal, int i) {
        this.doneSignal = doneSignal;
        this.i = i;
    }

    @Override
    public void run() {
        System.out.println("第"+i+"个人已到");
        doneSignal.countDown();
    }
}
public class Driver {
    private static final int N = 100;

    public static void main(String[] args) throws InterruptedException {
        CountDownLatch doneSignal = new CountDownLatch(N);
        ExecutorService executorService = Executors.newFixedThreadPool(10);
        for (int i =0;i<N;i++){
            executorService.submit(new Person(doneSignal,i));
        }
        doneSignal.await();
        System.out.println("人到齐,开车!");
    }
}

部分输出:
请添加图片描述

实现原理探究

public class CountDownLatch {
    /**
     * Synchronization control For CountDownLatch.
     * Uses AQS state to represent count.
     */
    private static final class Sync extends AbstractQueuedSynchronizer {
		...
		...
		...
    }
}

CountDownLatch是使用AQS实现的。使用AQS的状态变量来存放计数器的值。

countdown()方法:原子性递减AQS的状态值。
await()方法:当前线程会被放入AQS的阻塞队列等待计数器为0再返回。

《Java并发编程之美》
《Java高并发核心编程(卷2)》

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值