多线程学习--------CountDownLatch

1.概述

犹如倒计时计数器,调用CountDownLatch对象的countDown方法就将计数器减1,当计数到达0时,则所有等待者开始执行。

2.代码示例

public static void main(String[] args) {
		
		ExecutorService executorService = Executors.newCachedThreadPool();
		CountDownLatch orderLatch = new CountDownLatch(1);
		CountDownLatch answerLatch = new CountDownLatch(3);
		for(int i = 0;i < 3;i++){
			Runnable runnable = new Runnable() {
				@Override
				public void run() {
					try {
						System.out.println("线程"+Thread.currentThread().getName()+"正在等待接收命令");
						//等待命令
						orderLatch.await();
						//接收命令(orderLatch的数量减到0)
						System.out.println("线程"+Thread.currentThread().getName()+"已经接收命令");
						//执行
						Thread.sleep((long)Math.random()*10000);
						//执行完毕
						System.out.println("线程"+Thread.currentThread().getName()+"回应处理结果");
						//执行完某个线程,使得answerCountDownLatch减1
						answerLatch.countDown();
					} catch (InterruptedException e) {
						// TODO Auto-generated catch block
						e.printStackTrace();
					}
					
				}
			};
			executorService.execute(runnable);
		}
		try {
			Thread.sleep((long)Math.random()*10000);
			System.out.println("线程"+Thread.currentThread().getName()+"即将发布命令");
			//发布命令
			orderLatch.countDown();
			System.out.println("线程"+Thread.currentThread().getName()+"已经发布命令,正在等待结果");
			//等待所有的answer执行完
			answerLatch.await();
			//所有answer执行完毕,裁判拿到所有人的结果
			System.out.println("线程"+Thread.currentThread().getName()+"已经获取到所有结果");
		} catch (InterruptedException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		
		executorService.shutdown();
		
		
	}

运行结果:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
学习Java多线程的路线可以按照以下步骤进行: 1. 理解并掌握基本概念:首先,你需要了解什么是线程、进程和并发编程。了解线程的生命周期、线程的状态转换以及线程的调度方式等基本概念。 2. 学习线程的创建和启动:学习如何创建和启动线程,可以使用Thread类或者实现Runnable接口来创建线程。了解如何通过start()方法启动线程,并了解线程的运行机制。 3. 线程同步与互斥:学习如何处理多个线程之间的共享资源访问问题,掌握使用synchronized关键字实现线程同步和互斥。了解锁的概念、锁的种类以及锁的使用方式。 4. 线程通信与协作:学习如何实现多个线程之间的通信和协作,掌握使用wait()、notify()和notifyAll()方法实现线程间的等待和唤醒操作。了解条件变量的概念和使用方式。 5. 线程池的使用:学习如何使用线程池来管理和调度线程,掌握ThreadPoolExecutor类的使用方法。了解线程池的原理、优势和适用场景。 6. 并发工具类的使用:学习Java提供的并发工具类,如CountDownLatch、CyclicBarrier、Semaphore等,掌握它们的使用方法和适用场景。 7. 并发编程的高级主题:学习一些高级的并发编程主题,如原子操作类、并发集合类、并发队列等。了解并发编程中的常见问题和解决方案。 8. 多线程调试与性能优化:学习如何调试多线程程序,掌握常见的多线程调试技巧。了解如何进行多线程程序的性能优化,提高程序的并发性能。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值