`
yysct2005
  • 浏览: 91247 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

Java线程:新特征-障碍器

阅读更多
Java线程:新特征-障碍器
 
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
 
从执行结果可以看出,所有子任务完成的时候,主任务执行了,达到了控制的目标。

本文出自 “熔 岩” 博客,请务必保留此出处http://lavasoft.blog.51cto.com/62575/222738

分享到:
评论

相关推荐

    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多线程

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

    Java多线程运算集合

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

    java多线程编程总结

    #### 十一、Java线程:新特征 - **线程池** `ExecutorService` 和 `Executors` 提供了一种高效地管理线程的方式,减少了线程创建和销毁的开销。 - **有返回值的线程** 通过 `Callable` 接口和 `Future` 类可以...

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

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

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

    #### 五、Java线程的新特征详解 - **线程池**:高效地复用一组线程来执行任务,减少了创建和销毁线程的开销。 - **有返回值的线程**:通过`Callable`和`Future`实现线程的返回值,提供了更灵活的异步编程模型。 - *...

    JAVA多线程总结

    **七、Java线程的新特性** 1. **线程池**:`ExecutorService`管理线程,提高性能,避免资源浪费。 2. **有返回值的线程**:`Future`和`Callable`接口组合实现。 3. **锁**:`java.util.concurrent.locks`包提供了更...

    Java并发编程(22)并发新特性-障碍器CyclicBa

    在Java 5中引入的CyclicBarrier,它的名字"Barier"意味着障碍,而"Cyclic"则表示可以重用,即当所有等待的线程都到达屏障点后,屏障会自动重置,让下一轮的线程能够继续使用。 CyclicBarrier的主要方法有以下几个:...

    java线程文档大全

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

    Java 线程总结

    8. **Java线程的新特性**: - 线程池(ExecutorService):通过`Executors`类创建,可以更有效地管理线程的创建和销毁。 - 有返回值的线程:通过`Future`和`Callable`接口,可以在执行完成后获取结果。 - 锁机制...

    JAVA(坦克大战,多线程管理).rar

    "JAVA(坦克大战,多线程管理).rar"这个压缩包可能包含了一个基于Java实现的坦克大战游戏,其中涉及了多线程的概念来模拟游戏中的各种动态元素,如坦克、子弹、障碍物等的独立运动和交互。下面我们将深入探讨Java多...

    Java-多线程教学文档

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

    用java多线程写的贪吃蛇

    在本项目中,"用java多线程写的贪吃蛇"是一个基于Java编程语言实现的经典游戏——贪吃蛇。这个程序利用了Java的多线程技术来管理游戏的各个组件,如蛇、食物以及游戏窗口的更新。让我们深入探讨一下其中涉及的关键...

    java语言程序设计--吴倩_勘误表

    《Java语言程序设计》作为初学者学习Java编程的入门书籍,由吴倩老师撰写,一直深受广大编程爱好者的喜爱。由于Java语言的复杂性,以及编程语言本身不断更新的特点,即使是最精细的书籍也难以避免出现一些疏漏,如...

    java线程的详细解说

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

Global site tag (gtag.js) - Google Analytics