`
nowing
  • 浏览: 84724 次
  • 来自: ...
社区版块
存档分类
最新评论

Java线程:障碍器

阅读更多
http://lavasoft.blog.51cto.com/62575/222738

Java5中,添加了障碍器类,为了适应一种新的设计需求,比如一个大型的任务,常常需要分配好多子任务去执行,只有当所有子任务都执行完成时候,才能执行主任务,这时候,就可以选择障碍器了。

障碍器是多线程并发控制的一种手段,用法很简单。下面给个例子:

import java.util.concurrent.BrokenBarrierException;
import java.util.concurrent.CyclicBarrier;

/**
* Java线程:新特征-障碍器
*
* @author leizhimin 2009-11-6 10:50:10
*/
public class Test {
        public static void main(String[] args) {
                //创建障碍器,并设置MainTask为所有定数量的线程都达到障碍点时候所要执行的任务(Runnable)
                CyclicBarrier cb = new CyclicBarrier(7, new MainTask());
                new SubTask("A", cb).start();
                new SubTask("B", cb).start();
                new SubTask("C", cb).start();
                new SubTask("D", cb).start();
                new SubTask("E", cb).start();
                new SubTask("F", cb).start();
                new SubTask("G", cb).start();
        }
}

/**
* 主任务
*/
class MainTask implements Runnable {
        public void run() {
                System.out.println(">>>>主任务执行了!<<<<");
        }
}

/**
* 子任务
*/
class SubTask extends Thread {
        private String name;
        private CyclicBarrier cb;

        SubTask(String name, CyclicBarrier cb) {
                this.name = name;
                this.cb = cb;
        }

        public void run() {
                System.out.println("[子任务" + name + "]开始执行了!");
                for (int i = 0; i < 999999; i++) ;    //模拟耗时的任务
                System.out.println("[子任务" + name + "]开始执行完成了,并通知障碍器已经完成!");
                try {
                        //通知障碍器已经完成
                        cb.await();
                } catch (InterruptedException e) {
                        e.printStackTrace();
                } catch (BrokenBarrierException e) {
                        e.printStackTrace();
                }
        }
}

运行结果:
[子任务E]开始执行了!
[子任务E]开始执行完成了,并通知障碍器已经完成!
[子任务F]开始执行了!
[子任务G]开始执行了!
[子任务F]开始执行完成了,并通知障碍器已经完成!
[子任务G]开始执行完成了,并通知障碍器已经完成!
[子任务C]开始执行了!
[子任务B]开始执行了!
[子任务C]开始执行完成了,并通知障碍器已经完成!
[子任务D]开始执行了!
[子任务A]开始执行了!
[子任务D]开始执行完成了,并通知障碍器已经完成!
[子任务B]开始执行完成了,并通知障碍器已经完成!
[子任务A]开始执行完成了,并通知障碍器已经完成!
>>>>主任务执行了!<<<<

Process finished with exit code 0

从执行结果可以看出,所有子任务完成的时候,主任务执行了,达到了控制的目标。
分享到:
评论

相关推荐

    Java多线程编程总结

    Java线程:概念与原理 Java线程:创建与启动 Java线程:线程栈模型与线程的变量 Java线程:线程状态的转换 Java线程:线程的同步与锁 Java线程:线程的交互 ...Java线程:新特征-障碍器 Java线程:大总结

    java线程详解

    Java线程:概念与原理 Java线程:创建与启动 ...Java线程:新特征-障碍器 Java线程:深入ThreadLocal 一、标准例子 二、不用ThreadLocal 三、自己实现个ThreadLocal 四、透过现象看本质 Java线程:大总结

    Java多线程编程经验

    #### 二十一、Java线程:新特征-障碍器 障碍器(`CyclicBarrier`)是一种协调多个线程的工具,使得所有参与的线程都必须等待到达某个屏障点后才能继续执行。 #### 二十二、Java线程:大总结 Java多线程编程是Java...

    java多线程编程总结

    - **障碍器** `CyclicBarrier` 和 `CountDownLatch` 等类提供了线程间等待特定事件完成的机制。 #### 总结 Java多线程编程是Java语言中极其重要的一部分。从Java 5开始,Java引入了大量的新特性,显著增强了多...

    Java多线程

    #### 二十一、Java线程:新特征-障碍器 障碍器允许一组线程等待到达某个公共屏障点,所有线程都到达后才能继续执行。 #### 二十二、Java线程:大总结 Java多线程编程涉及到的概念广泛,从基础的线程创建到高级的...

    Java_多线程编程线程:大总结

    - **障碍器**:协调一组线程的执行,例如等待所有线程完成初始化后再开始工作。 #### 六、总结 Java多线程编程涵盖了从基础概念到高级特性的广泛内容。掌握Java线程不仅能够提升程序的并发处理能力,还能优化系统...

    JAVA多线程总结

    **一、Java线程:概念与原理** 1. **线程与进程**: - **进程**:是操作系统资源分配的基本单位,每个进程都有独立的内存空间。 - **线程**:是进程中的一个执行流,线程间共享进程的内存空间。在Java中,每个...

    Java多线程运算集合

    #### 十七、Java线程:新特征-障碍器 - **障碍器**: - `CyclicBarrier` 和 `CountDownLatch` 是两种常用的屏障类,用于实现线程间的同步等待。 - 这些工具可以用于确保一组线程在达到某个特定点之前等待,直到...

    java线程文档大全

    Java线程是多任务编程中的核心概念,它允许程序同时执行多个不同的任务,极大地提高了程序的效率和响应性。在Java中,线程是通过Java.lang.Thread类或实现Runnable接口来创建和管理的。这份“java线程文档大全”包含...

    用java多线程写的贪吃蛇

    线程负责定期更新蛇的位置,并检查是否与自身或其他障碍物发生碰撞。 5. **食物类(Food Class)**:食物在随机位置生成,当蛇吃掉食物时,蛇的长度会增加,食物会重新生成。食物类可能包含一个生成新食物位置的...

    java线程的详细解说

    另外,Java 5之后引入了更高级的并发工具类,如Semaphore(信号量)、BlockingQueue(阻塞队列)、CountDownLatch(计数障碍器)等,这些工具使得线程间的协调更加灵活和高效。 volatile关键字在多线程中用于保证...

    JAVA源码:坦克大战

    同时,这个项目也可以作为进一步深入学习JAVA高级特性和优化技巧的起点,比如线程同步、性能调优等。对于初学者来说,这是一个极具挑战性和趣味性的实践项目,有助于提升编程技能和解决问题的能力。

    Java 线程总结

    - 障碍器(CyclicBarrier):允许一组线程等待其他线程到达某个屏障点后再继续执行。 Java线程的深入理解和熟练使用是成为Java开发高手的关键一步,涵盖了并发编程的核心知识,对于编写高效、稳定的多线程程序至关...

    图灵图书:图解JAVA多线程设计模式

    - **CyclicBarrier:** 障碍,当指定数量的线程到达障碍点时,所有线程都被释放。 - **Semaphore:** 信号量,控制同时访问特定资源的线程数量。 #### 设计模式在多线程中的应用 **生产者消费者模式:** - **定义...

    java并非编程,合集(各种锁、并发集合、障碍器、线程同步).zip

    “障碍器”通常指的是CyclicBarrier或CountDownLatch,这些都是协调多个线程间同步的工具。CyclicBarrier允许一组线程等待所有线程到达屏障点后一起继续执行,而CountDownLatch则是一次性的计数器,可以用于让一个...

    Java项目:16款java游戏(java+swing)

    4. **线程管理**:Java多线程技术用于实现游戏循环,确保游戏的实时性。通常一个线程负责更新游戏状态,另一个线程负责渲染游戏画面。 5. **数据结构**:如数组、链表、队列和栈等,用于存储和管理游戏对象的状态,...

    Java-多线程教学文档

    Java线程调度包括线程的休眠、优先级、让步、合并和守护线程等策略。线程优先级可以调整线程执行的相对顺序,但不保证绝对的执行顺序。守护线程是一种服务线程,当所有非守护线程结束时,JVM会退出,即使仍有守护...

Global site tag (gtag.js) - Google Analytics