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
本文出自 51CTO.COM技术博客
分享到:
相关推荐
Java线程:概念与原理 Java线程:创建与启动 Java线程:线程栈模型与线程的变量 Java线程:线程状态的转换 Java线程:线程的同步与锁 Java线程:线程的交互 ...Java线程:新特征-障碍器 Java线程:大总结
Java线程:概念与原理 Java线程:创建与启动 ...Java线程:新特征-障碍器 Java线程:深入ThreadLocal 一、标准例子 二、不用ThreadLocal 三、自己实现个ThreadLocal 四、透过现象看本质 Java线程:大总结
#### 二十一、Java线程:新特征-障碍器 障碍器(`CyclicBarrier`)是一种协调多个线程的工具,使得所有参与的线程都必须等待到达某个屏障点后才能继续执行。 #### 二十二、Java线程:大总结 Java多线程编程是Java...
#### 二十一、Java线程:新特征-障碍器 障碍器允许一组线程等待到达某个公共屏障点,所有线程都到达后才能继续执行。 #### 二十二、Java线程:大总结 Java多线程编程涉及到的概念广泛,从基础的线程创建到高级的...
#### 十七、Java线程:新特征-障碍器 - **障碍器**: - `CyclicBarrier` 和 `CountDownLatch` 是两种常用的屏障类,用于实现线程间的同步等待。 - 这些工具可以用于确保一组线程在达到某个特定点之前等待,直到...
#### 十一、Java线程:新特征 - **线程池** `ExecutorService` 和 `Executors` 提供了一种高效地管理线程的方式,减少了线程创建和销毁的开销。 - **有返回值的线程** 通过 `Callable` 接口和 `Future` 类可以...
- **CyclicBarrier:** 障碍,当指定数量的线程到达障碍点时,所有线程都被释放。 - **Semaphore:** 信号量,控制同时访问特定资源的线程数量。 #### 设计模式在多线程中的应用 **生产者消费者模式:** - **定义...
#### 五、Java线程的新特征详解 - **线程池**:高效地复用一组线程来执行任务,减少了创建和销毁线程的开销。 - **有返回值的线程**:通过`Callable`和`Future`实现线程的返回值,提供了更灵活的异步编程模型。 - *...
**七、Java线程的新特性** 1. **线程池**:`ExecutorService`管理线程,提高性能,避免资源浪费。 2. **有返回值的线程**:`Future`和`Callable`接口组合实现。 3. **锁**:`java.util.concurrent.locks`包提供了更...
在Java 5中引入的CyclicBarrier,它的名字"Barier"意味着障碍,而"Cyclic"则表示可以重用,即当所有等待的线程都到达屏障点后,屏障会自动重置,让下一轮的线程能够继续使用。 CyclicBarrier的主要方法有以下几个:...
Java线程是多任务编程中的核心概念,它允许程序同时执行多个不同的任务,极大地提高了程序的效率和响应性。在Java中,线程是通过Java.lang.Thread类或实现Runnable接口来创建和管理的。这份“java线程文档大全”包含...
8. **Java线程的新特性**: - 线程池(ExecutorService):通过`Executors`类创建,可以更有效地管理线程的创建和销毁。 - 有返回值的线程:通过`Future`和`Callable`接口,可以在执行完成后获取结果。 - 锁机制...
"JAVA(坦克大战,多线程管理).rar"这个压缩包可能包含了一个基于Java实现的坦克大战游戏,其中涉及了多线程的概念来模拟游戏中的各种动态元素,如坦克、子弹、障碍物等的独立运动和交互。下面我们将深入探讨Java多...
Java线程调度包括线程的休眠、优先级、让步、合并和守护线程等策略。线程优先级可以调整线程执行的相对顺序,但不保证绝对的执行顺序。守护线程是一种服务线程,当所有非守护线程结束时,JVM会退出,即使仍有守护...
在本项目中,"用java多线程写的贪吃蛇"是一个基于Java编程语言实现的经典游戏——贪吃蛇。这个程序利用了Java的多线程技术来管理游戏的各个组件,如蛇、食物以及游戏窗口的更新。让我们深入探讨一下其中涉及的关键...
《Java语言程序设计》作为初学者学习Java编程的入门书籍,由吴倩老师撰写,一直深受广大编程爱好者的喜爱。由于Java语言的复杂性,以及编程语言本身不断更新的特点,即使是最精细的书籍也难以避免出现一些疏漏,如...
另外,Java 5之后引入了更高级的并发工具类,如Semaphore(信号量)、BlockingQueue(阻塞队列)、CountDownLatch(计数障碍器)等,这些工具使得线程间的协调更加灵活和高效。 volatile关键字在多线程中用于保证...