CountDownLatch用法:
需要调用CountDownLatch的await()方法来等待计数器归零(线程全部签到)。调用CountDownLatch的countDown()方法让计数器减一(签到)
package com.tch.test.concurrent.test; import java.util.Random; import java.util.concurrent.CountDownLatch; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; public class CountDownLatchTest { /** 线程数 */ private int num = 3; private Random random = new Random(); /** 开始运行的计数器 */ private CountDownLatch begin = new CountDownLatch(1); /** 所有线程签到的计数器 */ private CountDownLatch end = new CountDownLatch(num); private ExecutorService executor = Executors.newFixedThreadPool(5); public static void main(String[] args) { new CountDownLatchTest().test(); } private void test() { try { doTask(); System.out.println( "开始 "); //发出开始运行的信号 begin.countDown(); //主线程等待end计数器减到0,也就是所有线程都完成签到(end.countDown()) end.await(); System.out.println("结束 "+System.currentTimeMillis()); executor.shutdown(); } catch (InterruptedException e) { e.printStackTrace(); } } private void doTask(){ for(int i=0;i<num;i++){ executor.execute(new Task(i)); } } class Task implements Runnable{ private int id; public Task(int id){ this.id = id; } @Override public void run() { try { //等待begin的计数器减到0,导致当前线程进入阻塞状态 begin.await(); Thread.sleep(random.nextInt(1500)); System.out.println("线程"+id+"结束"+System.currentTimeMillis()); //向end计数器报到,end计时器减一 end.countDown(); //等待end计数器减到0,也就是等待所有线程都完成 end.await(); System.out.println("全部线程结束 "+System.currentTimeMillis()); } catch (InterruptedException e) { e.printStackTrace(); } } } }
CyclicBarrier用法:
调用CyclicBarrier的await()方法来签到 并且 等待其它线程全部签到完成。
package com.tch.test.concurrent.test; import java.util.Random; import java.util.concurrent.CyclicBarrier; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; public class CyclicBarrierTest { private CyclicBarrier barrier; /** 线程数 */ private int num = 3; private Random random = new Random(); private ExecutorService executor = Executors.newFixedThreadPool(5); public static void main(String[] args) { new CyclicBarrierTest().test(); } private void test() { barrier = new CyclicBarrier(num, new Runnable() { @Override public void run() { System.out.println("全部签到完成"+System.currentTimeMillis()); System.out.println(barrier.getNumberWaiting()+" "+barrier.getParties()); //barrier.reset(); System.out.println("--------------重新开始------------"); doTask(); } }); doTask(); barrier.reset(); //executor.shutdown(); } //barrier.reset(); private void doTask(){ for(int i=0;i<num;i++){ executor.execute(new Task(i)); } } class Task implements Runnable{ private int id; public Task(int id){ this.id = id; } @Override public void run() { try { Thread.sleep(random.nextInt(1500)); System.out.println("线程"+id+"结束"+System.currentTimeMillis()); barrier.await(); } catch (Exception e) { e.printStackTrace(); } } } }
相关推荐
在Java并发编程中,CountDownLatch和CyclicBarrier是两种非常重要的同步工具类,它们用于协调多个线程间的协作。这两个工具都是在`java.util.concurrent`包下,是Java并发库的重要组成部分。 **CountDownLatch** ...
在Java的并发编程中,CountDownLatch和CyclicBarrier是两个非常重要的同步工具,它们用于协调多个线程的执行顺序。本文将详细介绍CountDownLatch和CyclicBarrier的工作原理、使用场景以及如何在实际项目中应用它们。...
java并发编程中CountDownLatch和CyclicBarrier的使用借鉴 java并发编程中CountDownLatch和CyclicBarrier是两个非常重要的线程控制和调度工具,经常被用于解决多线程程序设计中的线程等待问题。本文将对...
在Java并发编程中,CountDownLatch和CyclicBarrier是两种非常重要的同步工具,用于协调多个线程之间的交互。它们都属于java.util.concurrent包下的类,为多线程编程提供了强大的支持。 **CountDownLatch** 是一个...
### CountDownLatch 和 CyclicBarrier 的运用(含AQS详解) #### CountDownLatch **定义与特点:** CountDownLatch 是 Java 并发包中的一个重要组件,它主要用于解决“一个或多个线程等待其他线程完成任务”的问题。...
java 高并发应用场景
在Java并发编程中,CountDownLatch和CyclicBarrier都是用于协调多线程间同步的重要工具,它们可以帮助开发者在特定条件满足时启动或者结束线程的执行。本文将详细探讨这两个类的内部实现机制以及它们在实际应用场景...
Java并发编程:CountDownLatch与CyclicBarrier和Semaphore的实例详解 Java并发编程是Java语言中的一种高级技术,用于处理多线程编程中的同步问题。Java 1.5中引入了几个高效的辅助类,包括CountDownLatch、...
在Java并发编程中,CountDownLatch、CyclicBarrier和Semaphore是三种重要的线程协作工具,它们都基于AbstractQueuedSynchronizer(AQS)框架来实现线程间的同步和协调。AQS是一个内置的锁和同步组件,它为构建高级...
本节主要讲解了Java并发包中线程同步器原理剖析,具体来说是 CountDownLatch 和 CyclicBarrier 的使用和原理剖析。 一、CountDownLatch CountDownLatch 是一个同步工具,它可以让一个线程等待其他线程完成某些操作...
CountDownLatch是Java并发编程中一个重要的工具类,用于协调多线程间的同步。它由Java并发包`java....在实际编程中,应根据具体需求选择CountDownLatch或CyclicBarrier,以及其他并发工具,以确保程序的正确性和性能。
Java进阶教程,面试大全1,可参考以下问题: Semaphore-信号灯机制。 synchronized在静态方法和普通方法的区别。 怎么实现所有线程在等待某个事件的发生...CountDownLatch和CyclicBarrier的用法,以及相互之间的差别。
Java进阶教程,面试大全1,可参考以下问题: Semaphore-信号灯机制。 synchronized在静态方法和普通方法的区别。 怎么实现所有线程在等待某个事件的发生...CountDownLatch和CyclicBarrier的用法,以及相互之间的差别。
4.1 CountDownLatch 4.2 CyclicBarrier 4.3 Semaphore 4.4 Exchanger 第五章:原子类和无锁编程 5.1 AtomicInteger与AtomicLong 5.2 AtomicReference 第六章:线程池及其应用 6.1 ThreadPoolExecutor 6.2...
目录: 简介 1.1 并发编程与线程同步 1.2 CountDownLatch概述 CountDownLatch的基本用法 2.1 创建CountDownLatch对象 2.2 await()方法 ...CountDownLatch与CyclicBarrier的对比 最佳实践与注意事项
CountDownLatch是Java并发编程中一个重要的同步工具类,它允许一个或多个线程等待其他线程完成操作。...通过阅读和理解提供的代码样例(如`countdownlatch`文件),可以进一步加深对CountDownLatch的理解和应用。
内容概要:本文详细介绍了Java线程的基本概念、线程的安全与同步机制、多种线程间通信方式、Java内存模型,以及线程池的原理与使用技巧,涵盖了许多常用的...此外,文章还包括了大量的图表和代码示例,便于理解和学习。
CountDownLatch、CyclicBarrier 和 Semaphore 等多线程协作机制都是 Java 并发编程中的重要组成部分。它们可以帮助开发者编写高效、可靠的多线程程序,解决复杂的并发问题。 在实际开发中,我们可以根据具体情况...
CountDownLatch是Java并发编程中一个重要的工具类,它属于java.util.concurrent包下的一个同步辅助类。这个类的设计目的是允许一个线程等待其他多个线程完成操作,然后再继续执行。CountDownLatch通常用于多线程协作...