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();
	}
}

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

扫描二维码关注公众号,回复: 4151571 查看本文章

猜你喜欢

转载自blog.csdn.net/nameIsHG/article/details/84259072