java 多线程 主线程等待子线程结束
来源:互联网 发布:2017淘宝捉猫猫红包 编辑:程序博客网 时间:2024/06/05 09:04
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class ExcetuorDemo2 {
public static void main(String[] args) {
ExecutorService service = Executors.newFixedThreadPool(5);
CountDownLatch cdl = new CountDownLatch(5);
Handler t1 = new Handler(cdl);
Handler t2 = new Handler(cdl);
Handler t3 = new Handler(cdl);
Handler t4 = new Handler(cdl);
Handler t5 = new Handler(cdl);
service.execute(t1);
service.execute(t2);
service.execute(t3);
service.execute(t4);
service.execute(t5);
service.shutdown();
try {
cdl.await();
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("over");
}
}
class Handler implements Runnable {
CountDownLatch cdl;
public Handler(CountDownLatch cdl){
this.cdl = cdl;
}
@Override
public void run() {
for(int i=0;i<1;i++){
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName() + " " + i);
}
cdl.countDown();
}
}
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class ExcetuorDemo2 {
public static void main(String[] args) {
ExecutorService service = Executors.newFixedThreadPool(5);
CountDownLatch cdl = new CountDownLatch(5);
Handler t1 = new Handler(cdl);
Handler t2 = new Handler(cdl);
Handler t3 = new Handler(cdl);
Handler t4 = new Handler(cdl);
Handler t5 = new Handler(cdl);
service.execute(t1);
service.execute(t2);
service.execute(t3);
service.execute(t4);
service.execute(t5);
service.shutdown();
try {
cdl.await();
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("over");
}
}
class Handler implements Runnable {
CountDownLatch cdl;
public Handler(CountDownLatch cdl){
this.cdl = cdl;
}
@Override
public void run() {
for(int i=0;i<1;i++){
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName() + " " + i);
}
cdl.countDown();
}
}
0 0
- java 多线程 主线程等待子线程结束
- java 主线程等待子线程结束
- Java主线程等待子线程结束
- 主线程等待子线程结束(多线程结束标识)
- 多线程001 - 主线程等待子线程结束
- JAVA主线程等待子线程全部结束
- java并发-主线程等待子线程结束
- java并发编程:主线程等待子线程结束 CountDownLatch
- 主线程等待子线程执行结束
- 主线程等待子线程结束
- Java:主线程和子线程-----主线程等待子线程结束
- java 多线程 主线程等待 子线程序列、并发结果
- Java多线程--主线程等待所有子线程执行完毕
- Java多线程--让主线程等待子线程执行完毕
- 异步回调 主线程等待子线程结束
- java 主线程 等待 子线程
- Java实现主线程等待子线程
- Java实现主线程等待子线程
- Java-反射
- 位域
- STL3—Set容器基础总结
- iOS8 Size Classes初探
- 把Android手机变成远程监控摄像头
- java 多线程 主线程等待子线程结束
- 回收段空间
- QT QMap介绍与使用
- HiveHelper
- LeetCode:Single NumberII
- python socket函数中,send 与sendall的区别与使用方法
- Javascript 装载和执行
- PHP json_decode不转义中文
- 真皮沙发之压纹皮特点