Java多线程之CountDownLatch学习

给出官网上的例子:http://docs.oracle.com/javase/7/docs/api/java/util/concurrent/CountDownLatch.html

Java中concurrent包中的CountDownLatch类说白了就是一个计数器,我们可以通过设置参数来进行计数,每次只能有一个线程去操作这个计数器,通过CountDown这个函数使得计数器的值减小,当计数器的值为0时,阻塞于await方法的线程才能得以执行。

例子:下面的程序中的主线程阻塞于await方法, 只有当5个线程都执行完了,主线程才能继续执行。

package com.test;

import java.util.Random;
import java.util.concurrent.CountDownLatch;


public class CountDownLatchDemo {
	
	private static final int N = 5;
	
	private CountDownLatch waitCountDownLatch = null;
	
	
	public static void main(String[] args) throws InterruptedException {
		
		 new CountDownLatchDemo();
	}
	
	
	public CountDownLatchDemo() throws InterruptedException {
		
		waitCountDownLatch = new CountDownLatch(N);
		
		for (int i = 0; i < N; ++i) {
			
			new MyThread(i).start();
		}
		
		waitCountDownLatch.await();
		
		System.out.println("所有线程已经执行完成");
	}
	
	
	class MyThread extends Thread {
		
		private int id;
		
		MyThread(int id) {
			
			this.id = id;
		}
		
		public void run() {
			
			try {
				
				System.out.println("线程 " + id + "正在执行" );
				Thread.sleep(new Random().nextInt(2) * 1000);
			} catch (InterruptedException ex) {
				ex.printStackTrace();
			} finally {
				
				waitCountDownLatch.countDown();
			}
		}
	}
}

注:CountDownLatch类中有以下几个方法

void 	await()
等待,直到计数器中的值减为0。

boolean	await(long timeout, TimeUnit unit)
可以自己设置超时时间,一旦超过这个时间,await线程被唤醒,如果返回true,说明计数器为0,否则,不为0。

void	countDown()
使得计数器的值减1。

long	getCount()
得到当前计数器的值。







  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java 中,CountDownLatch 是一种同步工具,它可以用来控制线程的执行顺序或者等待其他线程完成某些操作。下面是一个使用 CountDownLatch 的示例,用于实现多线程的协调: ```java import java.util.concurrent.CountDownLatch; public class MultiThreadExample { public static void main(String[] args) throws InterruptedException { int threadCount = 5; CountDownLatch latch = new CountDownLatch(threadCount); for (int i = 0; i < threadCount; i++) { Thread thread = new Thread(new Worker(latch)); thread.start(); } System.out.println("Main thread is waiting for workers to finish."); latch.await(); System.out.println("All workers have finished. Main thread can continue."); } static class Worker implements Runnable { private final CountDownLatch latch; public Worker(CountDownLatch latch) { this.latch = latch; } @Override public void run() { try { System.out.println("Worker is performing some task."); Thread.sleep(1000); System.out.println("Worker has finished its task."); } catch (InterruptedException e) { e.printStackTrace(); } finally { latch.countDown(); } } } } ``` 在上面的示例中,我们创建了一个 CountDownLatch 对象,并将其初始化为预期的线程数量(5)。然后,在主线程中创建了 5 个 Worker 线程,并启动它们。每个 Worker 线程都会执行一些任务,然后调用 `latch.countDown()` 来通知 CountDownLatch 已经完成了一部分工作。最后,主线程调用 `latch.await()` 来等待所有 Worker 线程完成任务。 当所有 Worker 线程完成任务后,主线程就会继续执行。这样,我们就通过 CountDownLatch 来协调多线程的执行顺序了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值