我是靠谱客的博主 传统大碗,最近开发中收集的这篇文章主要介绍CountDownLatch 门闩 实例详解,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

CountDownLatch 介绍

CountDownLatch是JAVA提供在java.util.concurrent包下的一个辅助类,可以把它看成是一个计数器,其内部维护着一个count计数,只不过对这个计数器的操作都是原子操作,同时只能有一个线程去操作这个计数器。如果调用对象上的await()方法,调用者就会一直阻塞,直到别人调用countDown方法,将计数减到0,才可以继续执行。

CountDownLatch可以避免等待队列,它可以让代码执行效率更高一些。

代码实例

final CountDownLatch latch = new CountDownLatch(1); //定义一个门闩(计数器),一旦定义,不可变。

门闩常用方法:

latch.await();                        等待门闩的开放,不是进入等待队列。

latch.countDown();               调用此方法,门闩减一

以一个案例讲解CountDownLatch门闩

要求:定义一个容器,该容器最大限度为10,当容器元素添加到第5个的时候,打印容器大小。

代码:

/**
 * CountDownLatch 门闩
 */
package concurrent.t02;

import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.CyclicBarrier;
import java.util.concurrent.Semaphore;
import java.util.concurrent.TimeUnit;

public class Test_03 {
	public static void main(String[] args) {
		final Test_03_Container t = new Test_03_Container();
		final CountDownLatch latch = new CountDownLatch(1);

		new Thread(new Runnable(){
			@Override
			public void run() {
				if(t.size() != 5){
					try {
						latch.await(); // 等待门闩的开放。 不是进入等待队列
					} catch (InterruptedException e) {
						e.printStackTrace();
					}
				}
				System.out.println("size = 5");
			}
		}).start();
		
		new Thread(new Runnable() {
			@Override
			public void run() {
				for(int i = 0; i < 10; i++){
					System.out.println("add Object to Container " + i);
					t.add(new Object());
					if(t.size() == 5){
						latch.countDown(); // 门闩-1
					}
					try {
						TimeUnit.SECONDS.sleep(1);
					} catch (Exception e) {
						e.printStackTrace();
					}
				}
			}
		}).start();
	}
}

class Test_03_Container{
	List<Object> container = new ArrayList<>();
	
	public void add(Object o){
		this.container.add(o);
	}
	
	public int size(){
		return this.container.size();
	}
}

门闩应用场景:马拉松比赛

最后

以上就是传统大碗为你收集整理的CountDownLatch 门闩 实例详解的全部内容,希望文章能够帮你解决CountDownLatch 门闩 实例详解所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(54)

评论列表共有 0 条评论

立即
投稿
返回
顶部