java.util.concurrent.Executors应用
来源:互联网 发布:windows 正版 编辑:程序博客网 时间:2024/05/29 16:25
写一个程序要求主线程等待子线程运行结束后退出,且子线程同时运行。
思路共享一个计数标志位,每个线程结束后都去更新这个计数标志位,主线程判断该计数标志位是否所有的线程都已经工作完成,但是为了不去浪费过多的CPU,主线程需要进行Thread.sleep(),但是Thread.sleep()也会倒是效率的下降,所以这样的方法并不完美。
查资料,发现java.util.concurrent包中有个名为Executors的类,可以创建线程池,于是仔细研究了一下,发现使用这个类构造一个线程池,可以很简单的解决这个问题。
先看一下用Executors实现上述问题的完整代码:
Main.class
package net.chinaideal.concurrency.executor;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class Main {
private static final int NTHREDS = 10;
public static void main(String[] args) {
ExecutorService executor = Executors.newFixedThreadPool(NTHREDS);
for (int i = 0; i < NTHREDS; i++) {
Runnable worker = new MyRunnable();
executor.execute(worker);
}
executor.shutdown();
while (!executor.isTerminated()) { }
System.out.println("Finished all threads");
}
}
MyRunnable.class
package net.chinaideal.concurrency.executor;
public class MyRunnable implements Runnable {
@Override
public void run() {
System.out.println(Thread.currentThread().getName());
}
}
通过Executors.newFixedThreadPool(n);创建制定个数的工作线程池。java.util.concurrent.ExecutorService接口继承自java.util.concurrent.Executor接口,而Executor.execute的方法提供了一个运行Runnable类的方法。
因此在这个程序的实例中,使用Executors.newFixedThreadPool获得一个ExecutorService的实例,并通过执行ExecutorService.execute的方法运行定义好的MyRunnable实例。
通过不断运行ExecutorService.isTerminated()方法检测全部的线程是否都已经运行结束,ExecutorService.shutdown()将使之前通过Executor.execute()提交的任务运行结束后关闭线程池。ExecutorService还提供了一个与ExecutorService.shutdown()对应的方法名为ExecutorService.shutdownNow()该方法试图将结束已经提交的任务并结束线程池。
如果我们不调用ExecutorService.shutdown()或者ExecutorService.shutdownNow()方法,主线程将会一直阻塞住。
- java.util.concurrent.Executors应用
- java.util.concurrent.Executors
- java.util.concurrent.Executors学习
- java.util.concurrent.Executors学习
- java.util.concurrent.Executors 多线程
- java.util.concurrent.Executors 类
- java.util.concurrent.Executors 类
- java.util.concurrent.Executors 类
- JDK源码阅读 java.util.concurrent.Executors相关分析
- java.util.concurrent 包中Executor与Executors的区别
- java.util.concurrent 包中Executor与Executors的区别
- java.util.concurrent包中线程池Executors的使用
- 【java】 java.util.concurrent
- java.util.concurrent.CyclicBarrier
- java.util.concurrent 学习
- java.util.concurrent包
- java.util.concurrent 架构
- java.util.concurrent
- traceroute工作原理
- C语言中操作字符串的一些函数源代码
- Cache块替换算法LRU
- Linux Oracle服务启动&停止脚本与开机自启动
- C/C++ 编码规范详解
- java.util.concurrent.Executors应用
- HEVC学习(一) —— HM的使用
- C中的typeof & type
- 黑马程序员_银行业务调度系统
- Oracle OCM 认证指南
- unbutn tomcat geoserver tomcat自动启动时不能加载gdal模块
- HEVC学习(二) —— HM的整体结构及一些基本概念
- C语言实验:输入一个整数的小写金额值,转化为大写金额值并输出
- HEVC学习(三) —— 帧内预测系列之一