创建线程池的方式有哪几种?
- 线程创建方式有哪几种?
- 什么是定长线程池?
- 什么是可缓存线程池?
//定长线程池
//解释:每当提交一个任务就创建一个线程,直到达到线程池的最大数量,这时线程数量不在变化,当线程发生错误结束时,线程池会补充一个新的线程
static ExecutorService fixedPool = Executors.newFixedThreadPool(3);
//定长可执行周期任务的线程池
static ScheduledExecutorService scheduledPool = Executors.newScheduledThreadPool(3);
//缓存线程池
//解释:如果线程池的容量超过了任务数,会自动回收空闲线程,任务增加时可以自动添加新线程,线程池的容量不限制
static ExecutorService cachedPool = Executors.newCachedThreadPool();
//单例线程池
//解释:线程异常结束,会创建一个新的线程,能确保任务按提交顺序执行
static ExecutorService singlePool = Executors.newSingleThreadExecutor();
//单例可执行周期任务的线程池
static ScheduledExecutorService singleScheduledPool = Executors.newSingleThreadScheduledExecutor();
//窃取线程池
//解释:不保证执行顺序,适合任务耗时差异较大
static ExecutorService workPool = Executors.newWorkStealingPool();
线程池创建方式有以上六种,下面来看看实例代码
package cn.zwolf.app.controller;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;
public class ThreadPoolTest {
//定长线程池
static ExecutorService fixedPool = Executors.newFixedThreadPool(3);
//定长可执行周期任务的线程池
static ScheduledExecutorService scheduledPool = Executors.newScheduledThreadPool(3);
//缓存线程池
static ExecutorService cachedPool = Executors.newCachedThreadPool();
//单例线程池
static ExecutorService singlePool = Executors.newSingleThreadExecutor();
//单例可执行周期任务的线程池
static ScheduledExecutorService singleScheduledPool = Executors.newSingleThreadScheduledExecutor();
//窃取线程池
static ExecutorService workPool = Executors.newWorkStealingPool();
public static void main(String[] args) {
//定长线程池
fixedThreadPool();
//定长可执行周期任务的线程池
scheduledThreadPool();
//缓存线程池
cachedThreadPool();
//单例线程池
singleThreadPool();
//单例可执行周期任务的线程池
singlnScheduledThreadPool();
//窃取线程池
workThreadPool();
}
//测试定长线程池,线程池的容量为3,提交6个任务,根据打印结果可以看出先执行前3个任务,3个任务结束后在执行后面的任务
private static void fixedThreadPool() {
threadPool(fixedPool );
fixedPool .shutdown();
}
private static void scheduledThreadPool() {
sThreadPool(scheduledPool);
scheduledPool.shutdown();
}
private static void cachedThreadPool() {
threadPool(cachedPool);
cachedPool .shutdown();
}
private static void singleThreadPool() {
threadPool(singlePool);
singlePool .shutdown();
}
private static void singlnScheduledThreadPool() {
sThreadPool(singleScheduledPool);
singleScheduledPool.shutdown();
}
private static void workThreadPool() {
threadPool(workPool);
workPool .shutdown();
}
private static void threadPool(ExecutorService e) {
for (int i = 0; i < 6; i++) {
final int index = i;
e.execute(new Runnable() {
@Override
public void run() {
try {
Thread.sleep(3000);
} catch (Exception e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName() + " index : " + index);
}
});
}
try {
Thread.sleep(4000);
} catch (Exception es) {
es.printStackTrace();
}
System.out.println("4秒后~");
}
private static void sThreadPool(ScheduledExecutorService e) {
for (int i = 0; i < 10; i++) {
final int index = i;
//scheduleWithFixedDelay =》 固定的延迟时间执行任务;
//scheduleAtFixedRate =》 固定的频率执行任务;
e.scheduleWithFixedDelay(new Runnable() {
@Override
public void run() {
System.out.println(Thread.currentThread().getName() + " index : " + index);
}
},0,3, TimeUnit.SECONDS);
}
try {
Thread.sleep(4000);
} catch (Exception es) {
es.printStackTrace();
}
System.out.println("4秒后~");
}
}
看完这篇文章和实践操作之后,对上面的问答题是否已经有了清楚的了解了和认识了呢?