Java多线程之CountDownLatch(一)
2013-10-02 20:50
316 查看
package three.day.thread;
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class CountdownLatchTest {
public static void main(String[] args) {
ExecutorService service = Executors.newCachedThreadPool();
final CountDownLatch cdOrder = new CountDownLatch(1);
final CountDownLatch cdAnswer = new CountDownLatch(3);
for(int i=0;i<3;i++){
Runnable runnable = new Runnable(){
public void run(){
try {
while (true) {
System.out.println("线程"
+ Thread.currentThread().getName()
+ "正准备接受命令");
cdOrder.await();
System.out.println("线程"
+ Thread.currentThread().getName()
+ "已接受命令");
Thread.sleep((long) (Math.random() * 10000));
System.out.println("线程"
+ Thread.currentThread().getName()
+ "回应命令处理结果");
cdAnswer.countDown();
}
} catch (Exception e) {
e.printStackTrace();
}
}
};
service.execute(runnable);
}
try {
while (true) {
Thread.sleep((long) (Math.random() * 10000));
System.out.println("线程" + Thread.currentThread().getName()
+ "即将发布命令");
cdOrder.countDown();
System.out.println("线程" + Thread.currentThread().getName()
+ "已发送命令,正在等待结果");
cdAnswer.await();
System.out.println("线程" + Thread.currentThread().getName()
+ "已收到所有响应结果");
}
} catch (Exception e) {
e.printStackTrace();
}
service.shutdown();
}
}
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class CountdownLatchTest {
public static void main(String[] args) {
ExecutorService service = Executors.newCachedThreadPool();
final CountDownLatch cdOrder = new CountDownLatch(1);
final CountDownLatch cdAnswer = new CountDownLatch(3);
for(int i=0;i<3;i++){
Runnable runnable = new Runnable(){
public void run(){
try {
while (true) {
System.out.println("线程"
+ Thread.currentThread().getName()
+ "正准备接受命令");
cdOrder.await();
System.out.println("线程"
+ Thread.currentThread().getName()
+ "已接受命令");
Thread.sleep((long) (Math.random() * 10000));
System.out.println("线程"
+ Thread.currentThread().getName()
+ "回应命令处理结果");
cdAnswer.countDown();
}
} catch (Exception e) {
e.printStackTrace();
}
}
};
service.execute(runnable);
}
try {
while (true) {
Thread.sleep((long) (Math.random() * 10000));
System.out.println("线程" + Thread.currentThread().getName()
+ "即将发布命令");
cdOrder.countDown();
System.out.println("线程" + Thread.currentThread().getName()
+ "已发送命令,正在等待结果");
cdAnswer.await();
System.out.println("线程" + Thread.currentThread().getName()
+ "已收到所有响应结果");
}
} catch (Exception e) {
e.printStackTrace();
}
service.shutdown();
}
}
相关文章推荐
- 【Java多线程与并发库】14.java5的CountDownLatch同步工具
- Java多线程知识点整理(CyclicBarrier、CountDownLatch、Callable、Future和FutureTask)
- Java多线程之~~~使用CountDownLatch来同步多个线程实现一个任务
- Java多线程:CountDownLatch、CyclicBarrier 和 Semaphore
- Java多线程20:多线程下的其他组件之CountDownLatch、Semaphore、Exchanger
- java多线程编程之CountDownLatch
- Java多线程(八)之Semaphore、CountDownLatch、CyclicBarrier、Exchanger
- Java 多线程协调工具 CyclicBarrier 与CountDownLatch 学习
- java多线程之CountdownLatch简单应用
- java多线程发令枪CountDownLatch
- Java多线程之CountDownLatch
- java:运用CountDownLatch在多线程后获得正确值
- java多线程 关于synchronized wait notify CountDownLatch CyclicBarrier Semaphore
- 【Java多线程】JUC包下的工具类CountDownLatch、CyclicBarrier和Semaphore
- Java:多线程等待所有线程结束(CountDownLatch/CyclicBarrier) .
- Java多线程协作CountDownLatch,主线程等待子线程结束
- Java多线程系列-多线程下的其他组件之CountDownLatch、Semaphore、Exchanger
- Java核心知识点学习----多线程 倒计时记数器CountDownLatch和数据交换的Exchanger
- Java:多线程等待所有线程结束(CountDownLatch/CyclicBarrier) .
- Java多线程系列--“JUC锁”09之 CountDownLatch原理和示例 (r)