countdownlatch

mac2024-12-11  32

CountDownLatch (倒计时器)

CountDownLatch是一个同步工具类。 它允许一个或多个线程一直等待,直到其他线程的操作执行完后再执行。

CountDownLatch 的三种典型用法: 某一线程执行前,要等待n个线程执行完毕,在countDownlatch初始化传入n,在一个线程执行完毕后,通过countdown()讲计数器减1,当计数器为0是,调用await(),唤醒等待的线程

CycllcBarrier和countDownLatch想死,可以实现线程间的技术等待,但比他功能要强大,他让一组现成到达一个同步点是被阻塞,知道最后一个线程执行完毕才会开门,所有被阻塞的线程才会继续干活

5.1 CyclicBarrier 的应用场景

CyclicBarrier 可以用于多线程计算数据,最后合并计算结果的应用场景。比如我们用一个Excel保存了用户所有银行流水,每个Sheet保存一个帐户近一年的每笔银行流水,现在需要统计用户的日均银行流水,先用多线程处理每个sheet里的银行流水,都执行完之后,得到每个sheet的日均银行流水,最后,再用barrierAction用这些线程的计算结果,计算出整个Excel的日均银行流水。

synchronized解决的是线程之间访问资源的同步性,可以修饰方法或代码块,在任意时刻只有一个线程执行

怎么使用它: 用在方法和代码块中,表示给对象上锁, 用在静态方法中,表示给类上锁,线程a访问非静态synchronized方法,然后线程b是可以访问静态synchronized方法。

synchronized关键字解决的是多个线程之间访问资源的同步性,synchronized关键字可以保证被它修饰的方法或者代码块在任意时刻只能有一个线程执行。

最新回复(0)