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线程:深入ThreadLocal 一、标准例子 二、不用ThreadLocal 三、自己实现个ThreadLocal 四、透过现象看本质 Java线程:大总结
#### 二十一、Java线程:新特征-障碍器 障碍器(`CyclicBarrier`)是一种协调多个线程的工具,使得所有参与的线程都必须等待到达某个屏障点后才能继续执行。 #### 二十二、Java线程:大总结 Java多线程编程是Java...
- **障碍器** `CyclicBarrier` 和 `CountDownLatch` 等类提供了线程间等待特定事件完成的机制。 #### 总结 Java多线程编程是Java语言中极其重要的一部分。从Java 5开始,Java引入了大量的新特性,显著增强了多...
#### 二十一、Java线程:新特征-障碍器 障碍器允许一组线程等待到达某个公共屏障点,所有线程都到达后才能继续执行。 #### 二十二、Java线程:大总结 Java多线程编程涉及到的概念广泛,从基础的线程创建到高级的...
- **障碍器**:协调一组线程的执行,例如等待所有线程完成初始化后再开始工作。 #### 六、总结 Java多线程编程涵盖了从基础概念到高级特性的广泛内容。掌握Java线程不仅能够提升程序的并发处理能力,还能优化系统...
**一、Java线程:概念与原理** 1. **线程与进程**: - **进程**:是操作系统资源分配的基本单位,每个进程都有独立的内存空间。 - **线程**:是进程中的一个执行流,线程间共享进程的内存空间。在Java中,每个...
#### 十七、Java线程:新特征-障碍器 - **障碍器**: - `CyclicBarrier` 和 `CountDownLatch` 是两种常用的屏障类,用于实现线程间的同步等待。 - 这些工具可以用于确保一组线程在达到某个特定点之前等待,直到...
Java线程是多任务编程中的核心概念,它允许程序同时执行多个不同的任务,极大地提高了程序的效率和响应性。在Java中,线程是通过Java.lang.Thread类或实现Runnable接口来创建和管理的。这份“java线程文档大全”包含...
线程负责定期更新蛇的位置,并检查是否与自身或其他障碍物发生碰撞。 5. **食物类(Food Class)**:食物在随机位置生成,当蛇吃掉食物时,蛇的长度会增加,食物会重新生成。食物类可能包含一个生成新食物位置的...
另外,Java 5之后引入了更高级的并发工具类,如Semaphore(信号量)、BlockingQueue(阻塞队列)、CountDownLatch(计数障碍器)等,这些工具使得线程间的协调更加灵活和高效。 volatile关键字在多线程中用于保证...
同时,这个项目也可以作为进一步深入学习JAVA高级特性和优化技巧的起点,比如线程同步、性能调优等。对于初学者来说,这是一个极具挑战性和趣味性的实践项目,有助于提升编程技能和解决问题的能力。
- 障碍器(CyclicBarrier):允许一组线程等待其他线程到达某个屏障点后再继续执行。 Java线程的深入理解和熟练使用是成为Java开发高手的关键一步,涵盖了并发编程的核心知识,对于编写高效、稳定的多线程程序至关...
- **CyclicBarrier:** 障碍,当指定数量的线程到达障碍点时,所有线程都被释放。 - **Semaphore:** 信号量,控制同时访问特定资源的线程数量。 #### 设计模式在多线程中的应用 **生产者消费者模式:** - **定义...
“障碍器”通常指的是CyclicBarrier或CountDownLatch,这些都是协调多个线程间同步的工具。CyclicBarrier允许一组线程等待所有线程到达屏障点后一起继续执行,而CountDownLatch则是一次性的计数器,可以用于让一个...
4. **线程管理**:Java多线程技术用于实现游戏循环,确保游戏的实时性。通常一个线程负责更新游戏状态,另一个线程负责渲染游戏画面。 5. **数据结构**:如数组、链表、队列和栈等,用于存储和管理游戏对象的状态,...
Java线程调度包括线程的休眠、优先级、让步、合并和守护线程等策略。线程优先级可以调整线程执行的相对顺序,但不保证绝对的执行顺序。守护线程是一种服务线程,当所有非守护线程结束时,JVM会退出,即使仍有守护...