Java 线程池规范使用示例(java线程池入门)
yund56 2025-07-08 23:23 20 浏览
1 摘要
Java 线程池在批量处理的场景中应用广泛。常见的四种创建线程池的方法:newSingleThreadExecutor,newFixedThreadPool,newCachedThreadPool,newScheduledThreadPool,各有各的缺陷,不建议使用。本文将给出根据阿里巴巴Java开发手册推荐的方式创建线程池的示例。
2 推荐创建线程池的方法
java.util.concurrent.ThreadPoolExecutor
ThreadPoolExecutor(int corePoolSize,
int maximumPoolSize,
long keepAliveTime,
TimeUnit unit,
BlockingQueue<Runnable> workQueue,
ThreadFactory threadFactory,
RejectedExecutionHandler handler)
参数说明:
corePoolSize: 线程池核心线程数量,推荐为服务器的核心数量
maximumPoolSize: 线程池最大线程数量,推荐为和服务核心数量的两倍
keepAliveTime: 线程销毁等待时间,当线程数超过核心线程数量(corePoolSize)时,销毁多余线程需要等待的最大时间;可根据任务执行的频率设置时间长度
unit: 线程销毁等待时间单位,有毫秒,秒,小时等
workQueue: 工作负载阻塞队列,当线程池中线程数量达到最大值时,仍然有未处理的任务,此时会将任务放在该队列中
threadFactory: 线程工厂,用于创建线程
RejectedExecutionHandler: 线程池拒绝策略,当线程数量达到线程池最大值,工作负载队列满了之后,线程池对于新任务的处理策略。有四种:
java.util.concurrent.ThreadPoolExecutor.AbortPolicy: 抛出异常,不作处理
java.util.concurrent.ThreadPoolExecutor.DiscardPolicy: 丢弃新任务,也不抛出异常
java.util.concurrent.ThreadPoolExecutor.DiscardOldestPolicy: 丢弃最老的任务
java.util.concurrent.ThreadPoolExecutor.CallerRunsPolicy: 把任务交给调用线程池的线程处理,直到线程池死了
通常情况下选择抛出异常的策略即可。
3 核心示例代码
3.1 任务负载
./src/main/java/com/ljq/demo/concurrent/DrinkTask.java
1
package com.ljq.demo.concurrent;
import lombok.extern.slf4j.Slf4j;
import java.util.concurrent.Callable;
/**
* @Description: 喝酒任务
* @Author: junqiang.lu
* @Date: 2021/5/14
*/
@Slf4j
public class DrinkTask implements Callable<Integer> {
/**
* 当前杯数
*/
private int cupNumber;
public DrinkTask(int cupNumber) {
this.cupNumber = cupNumber;
}
@Override
public Integer call() throws Exception {
log.info("武松喝完了第[" + cupNumber + "]杯酒");
Thread.sleep(100);
return cupNumber;
}
}
3.2 简易线程池工具类
./src/main/java/com/ljq/demo/util/ThreadPoolUtil.java
1
package com.ljq.demo.util;
import cn.hutool.core.thread.ThreadFactoryBuilder;
import java.util.concurrent.*;
/**
* @Description: 线程池工具类
* @Author: junqiang.lu
* @Date: 2021/5/14
*/
public class ThreadPoolUtil {
private ThreadPoolUtil(){
}
static {
initExecutor();
}
/**
* 线程池执行器
*/
private static transient ThreadPoolExecutor executor;
/**
* 执行任务
* (不包含返回值)
*
* @param command
*/
public static void execute(Runnable command) {
executor.execute(command);
}
/**
* 执行任务
* (包含返回值)
*
* @param task
* @param <T>
* @return
*/
public static <T> Future<T> executeAsync(Callable<T> task) {
return executor.submit(task);
}
/**
* 销毁线程池
*/
public static void shutdown() {
executor.shutdown();
}
/**
* 初始化线程池
*/
private static void initExecutor() {
if (executor == null || executor.isShutdown()) {
synchronized (ThreadPoolUtil.class) {
if (executor == null || executor.isShutdown()) {
executor = new ThreadPoolExecutor(4,10,100,
TimeUnit.MILLISECONDS, new ArrayBlockingQueue<>(1000),
ThreadFactoryBuilder.create().build(), new ThreadPoolExecutor.AbortPolicy());
}
}
}
}
}
3.3 线程池运行测试示例
./src/main/java/com/ljq/demo/concurrent/DrinkThreadPoolDemo.java
1
package com.ljq.demo.concurrent;
import cn.hutool.core.thread.ThreadFactoryBuilder;
import cn.hutool.core.thread.ThreadUtil;
import com.ljq.demo.util.ThreadPoolUtil;
import lombok.extern.slf4j.Slf4j;
import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;
/**
* @Description: 喝酒线程池示例
* @Author: junqiang.lu
* @Date: 2021/5/14
*/
@Slf4j
public class DrinkThreadPoolDemo {
public static void main(String[] args) {
manualThreadPool();
huToolThreadUtil();
localThreadPoolUtil();
}
/**
* 手动创建线程池
*/
public static void manualThreadPool() {
// 创建线程池
ThreadPoolExecutor executor = new ThreadPoolExecutor(2,10,100,
TimeUnit.MILLISECONDS, new ArrayBlockingQueue<>(1000), ThreadFactoryBuilder.create().build(),
new ThreadPoolExecutor.AbortPolicy());
// 总杯数
int totalCup = 100;
int cupNumber;
for (int i = 1; i <= totalCup; i++) {
try {
cupNumber = executor.submit(new DrinkTask(i)).get();
log.info("manual cupNumber: {}", cupNumber);
} catch (InterruptedException e) {
log.error("线程池执行错误", e);
} catch (ExecutionException e) {
log.error("武松喝醉了", e);
}
}
// 关闭线程池
executor.shutdown();
}
/**
* 使用 hutool 线程工具类
* (线程池不会自动销毁)
*/
public static void huToolThreadUtil() {
// 总杯数
int totalCup = 100;
int cupNumber;
for (int i = 1; i <= totalCup; i++) {
try {
cupNumber = ThreadUtil.execAsync(new DrinkTask(i)).get();
log.info("hutool cupNumber: {}", cupNumber);
} catch (InterruptedException e) {
log.error("线程池执行错误", e);
} catch (ExecutionException e) {
log.error("武松喝醉了", e);
}
}
}
/**
* 本地线程池工具类
*/
public static void localThreadPoolUtil() {
// 总杯数
int totalCup = 100;
int cupNumber;
for (int i = 1; i <= totalCup; i++) {
try {
cupNumber = ThreadPoolUtil.executeAsync(new DrinkTask(i)).get();
log.info("local cupNumber: {}", cupNumber);
} catch (InterruptedException e) {
log.error("线程池执行错误", e);
} catch (ExecutionException e) {
log.error("武松喝醉了", e);
}
}
ThreadPoolUtil.shutdown();
}
}
3.4 部分执行日志
2021-05-14 16:50:58:890 [pool-4-thread-1] INFO
com.ljq.demo.concurrent.DrinkTask(DrinkTask.java 26) -武松喝完了第[1]杯酒
2021-05-14 16:50:58:992 [main] INFO com.ljq.demo.concurrent.DrinkThreadPoolDemo(DrinkThreadPoolDemo.java 82) -local cupNumber: 1
2021-05-14 16:50:58:993 [pool-4-thread-2] INFO
com.ljq.demo.concurrent.DrinkTask(DrinkTask.java 26) -武松喝完了第[2]杯酒
2021-05-14 16:50:59:094 [main] INFO com.ljq.demo.concurrent.DrinkThreadPoolDemo(DrinkThreadPoolDemo.java 82) -local cupNumber: 2
2021-05-14 16:50:59:095 [pool-4-thread-3] INFO
com.ljq.demo.concurrent.DrinkTask(DrinkTask.java 26) -武松喝完了第[3]杯酒
2021-05-14 16:50:59:199 [main] INFO com.ljq.demo.concurrent.DrinkThreadPoolDemo(DrinkThreadPoolDemo.java 82) -local cupNumber: 3
2021-05-14 16:50:59:200 [pool-4-thread-4] INFO
com.ljq.demo.concurrent.DrinkTask(DrinkTask.java 26) -武松喝完了第[4]杯酒
2021-05-14 16:50:59:301 [main] INFO com.ljq.demo.concurrent.DrinkThreadPoolDemo(DrinkThreadPoolDemo.java 82) -local cupNumber: 4
2021-05-14 16:50:59:301 [pool-4-thread-1] INFO
com.ljq.demo.concurrent.DrinkTask(DrinkTask.java 26) -武松喝完了第[5]杯酒
2021-05-14 16:50:59:401 [main] INFO com.ljq.demo.concurrent.DrinkThreadPoolDemo(DrinkThreadPoolDemo.java 82) -local cupNumber: 5
... ...
2021-05-14 16:51:08:694 [pool-4-thread-4] INFO
com.ljq.demo.concurrent.DrinkTask(DrinkTask.java 26) -武松喝完了第[96]杯酒
2021-05-14 16:51:08:794 [main] INFO com.ljq.demo.concurrent.DrinkThreadPoolDemo(DrinkThreadPoolDemo.java 82) -local cupNumber: 96
2021-05-14 16:51:08:795 [pool-4-thread-1] INFO
com.ljq.demo.concurrent.DrinkTask(DrinkTask.java 26) -武松喝完了第[97]杯酒
2021-05-14 16:51:08:897 [main] INFO com.ljq.demo.concurrent.DrinkThreadPoolDemo(DrinkThreadPoolDemo.java 82) -local cupNumber: 97
2021-05-14 16:51:08:897 [pool-4-thread-2] INFO
com.ljq.demo.concurrent.DrinkTask(DrinkTask.java 26) -武松喝完了第[98]杯酒
2021-05-14 16:51:08:998 [main] INFO com.ljq.demo.concurrent.DrinkThreadPoolDemo(DrinkThreadPoolDemo.java 82) -local cupNumber: 98
2021-05-14 16:51:08:999 [pool-4-thread-3] INFO
com.ljq.demo.concurrent.DrinkTask(DrinkTask.java 26) -武松喝完了第[99]杯酒
2021-05-14 16:51:09:101 [main] INFO com.ljq.demo.concurrent.DrinkThreadPoolDemo(DrinkThreadPoolDemo.java 82) -local cupNumber: 99
2021-05-14 16:51:09:102 [pool-4-thread-4] INFO
com.ljq.demo.concurrent.DrinkTask(DrinkTask.java 26) -武松喝完了第[100]杯酒
相关推荐
- SM小分队Girls on Top,女神战队少了f(x)?
-
这次由SM娱乐公司在冬季即将开演的smtown里,将公司的所有女团成员集结成了一个小分队project。第一位这是全面ACE的大姐成员权宝儿(BoA),出道二十年,在日本单人销量过千万,韩国国内200...
- 韩国女团 aespa 首场 VR 演唱会或暗示 Quest 3 将于 10 月推出
-
AmazeVR宣布将在十月份举办一场现场VR音乐会,观众将佩戴MetaQuest3进行体验。韩国女团aespa于2020年11月出道,此后在日本推出了三张金唱片,在韩国推出了...
- 韩网热议!女团aespa成员Giselle在长腿爱豆中真的是legend
-
身高163的Giselle,长腿傲人,身材比例绝了...
- 假唱而被骂爆的女团:IVE、NewJeans、aespa上榜
-
在韩国,其实K-pop偶像并不被认为是真正的歌手,因为偶像们必须兼备舞蹈能力、也经常透过对嘴来完成舞台。由于科技的日渐发达,也有许多网友会利用消音软体来验证K-pop偶像到底有没有开麦唱歌,导致假唱这...
- 新女团Aespa登时尚大片 四个少女四种style
-
来源:环球网
- 韩国女团aespa新歌MV曝光 画面梦幻造型超美
-
12月20日,韩国女团aespa翻唱曲《DreamsComeTrue》MV公开,视频中,她们的造型超美!WINTER背后长出一双梦幻般的翅膀。柳智敏笑容甜美。宁艺卓皮肤白皙。GISELLE五官精致...
- 女网友向拳头维权,自称是萨勒芬妮的原型?某韩国女团抄袭KDA
-
女英雄萨勒芬妮(Seraphine)是拳头在2020年推出的第五位新英雄,在还没有正式上线时就备受lsp玩家的关注,因为她实在是太可爱了。和其他新英雄不同的是,萨勒芬妮在没上线时就被拳头当成虚拟偶像来...
- 人气TOP女团是?INS粉丝数见分晓;TWICE成员为何在演唱会落泪?
-
现在的人气TOP女团是?INS粉丝数见分晓!现在爱豆和粉丝之间的交流方法变得多种多样,但是Instagram依然是主要的交流手段。很多粉丝根据粉丝数评价偶像的人气,拥有数百、数千万粉丝的组合作为全球偶...
- 韩国女团MVaespa Drama MV_韩国女团穿超短裙子跳舞
-
WelcometoDrama.Pleasefollow4ruleswhilewatchingtheDrama.·1)Lookbackimmediatelywhenyoufe...
- aespa师妹团今年将出道! SM职员亲口曝「新女团风格、人数」
-
记者刘宛欣/综合报导南韩造星工厂SM娱乐曾打造出东方神起、SUPERJUNIOR、少女时代、SHINee、EXO等传奇团体,近年推出的aespa、RIIZE更是双双成为新生代一线团体,深受大众与粉丝...
- 南韩最活跃的女团aespa,新专辑《Girls》即将发布,盘点昔日经典
-
女团aespa歌曲盘点,新专辑《Girls》即将发布,期待大火。明天也就是2022年的7月8号,aespa新专辑《Girls》即将发行。这是继首张专辑《Savage》之后,时隔19个月的第二张专辑,这...
- 章泽天女团aespa出席戛纳晚宴 宋康昊携新片亮相
-
搜狐娱乐讯(山今/文玄反影/图科明/视频)法国时间5月23日晚,女团aespa、宋康昊、章泽天等明星亮相戛纳晚宴。章泽天身姿优越。章泽天肩颈线优越。章泽天双臂纤细。章泽天仪态端正。女团aespa亮...
- Aespa舞台暴露身高比例,宁艺卓脸大,柳智敏有“TOP”相
-
作为SM公司最新女团aespa,初舞台《BlackMamba》公开,在初舞台里,看得出来SM公司是下了大功夫的,虽然之前SM公司新出的女团都有很长的先导片,但是aespa显然是有“特殊待遇”。运用了...
- AESPA女团成员柳智敏karina大美女
-
真队内速度最快最火达成队内首个且唯一两百万点赞五代男女团中输断层第一(图转自微博)...
- 对来学校演出的女团成员语言性骚扰?韩国这所男高的学生恶心透了
-
哕了……本月4日,景福男子高中相关人士称已经找到了在SNS中上传对aespa成员进行性骚扰文章的学生,并开始着手调查。2日,SM娱乐创始人李秀满的母校——景福高中迎来了建校101周年庆典活动。当天,S...
- 一周热门
- 最近发表
-
- SM小分队Girls on Top,女神战队少了f(x)?
- 韩国女团 aespa 首场 VR 演唱会或暗示 Quest 3 将于 10 月推出
- 韩网热议!女团aespa成员Giselle在长腿爱豆中真的是legend
- 假唱而被骂爆的女团:IVE、NewJeans、aespa上榜
- 新女团Aespa登时尚大片 四个少女四种style
- 韩国女团aespa新歌MV曝光 画面梦幻造型超美
- 女网友向拳头维权,自称是萨勒芬妮的原型?某韩国女团抄袭KDA
- 人气TOP女团是?INS粉丝数见分晓;TWICE成员为何在演唱会落泪?
- 韩国女团MVaespa Drama MV_韩国女团穿超短裙子跳舞
- aespa师妹团今年将出道! SM职员亲口曝「新女团风格、人数」
- 标签列表
-
- filter函数js (37)
- filter函数excel用不了 (73)
- 商城开发 (40)
- 影视网站免费源码最新版 (57)
- 影视资源api接口 (46)
- 网站留言板代码大全 (56)
- java版软件下载 (52)
- java教材电子课本下载 (48)
- 0基础编程从什么开始学 (50)
- java是用来干嘛的 (51)
- it入门应该学什么 (55)
- java线上课程 (55)
- 学java的软件叫什么软件 (38)
- 程序开发软件有哪些 (53)
- 软件培训 (59)
- 机器人编程代码大全 (50)
- 少儿编程教程免费 (45)
- 新代系统编程教学 (61)
- 共创世界编程网站 (38)
- 亲测源码 (36)
- 三角函数积分公式表 (35)
- 函数的表示方法 (34)
- 表格乘法的公式怎么设置 (34)
- sumif函数的例子 (34)
- 图片素材 (36)
