hutool中的threadutil_hutool-core/src/main/java/cn/hutool/core/thread/ThreadUtil.java · 零度/hutool - Git...

Hutool是一个Java工具包,提供了线程池工具类ThreadUtil,包括创建不同类型的线程池、执行线程任务、获取线程信息等功能。线程池的创建可以根据需求设置核心线程数、最大线程数、阻塞系数等参数,同时提供了方便的异步执行方法和线程异常处理。
摘要由CSDN通过智能技术生成

package cn.hutool.core.thread;

import java.lang.Thread.UncaughtExceptionHandler;

import java.util.concurrent.Callable;

import java.util.concurrent.CompletionService;

import java.util.concurrent.CountDownLatch;

import java.util.concurrent.ExecutorCompletionService;

import java.util.concurrent.ExecutorService;

import java.util.concurrent.Executors;

import java.util.concurrent.Future;

import java.util.concurrent.SynchronousQueue;

import java.util.concurrent.ThreadFactory;

import java.util.concurrent.ThreadPoolExecutor;

import java.util.concurrent.TimeUnit;

/**

* 线程池工具

*

* @author luxiaolei

*/

public class ThreadUtil {

/**

* 新建一个线程池

*

* @param threadSize 同时执行的线程数大小

* @return ExecutorService

*/

public static ExecutorService newExecutor(int threadSize) {

return ExecutorBuilder.create().setCorePoolSize(threadSize).build();

}

/**

* 获得一个新的线程池

*

* @return ExecutorService

*/

public static ExecutorService newExecutor() {

return ExecutorBuilder.create().setWorkQueue(new SynchronousQueue()).build();

}

/**

* 获得一个新的线程池,只有单个线程

*

* @return ExecutorService

*/

public static ExecutorService newSingleExecutor() {

return Executors.newSingleThreadExecutor();

}

/**

* 获得一个新的线程池

* 如果maximumPoolSize =》 corePoolSize,在没有新任务加入的情况下,多出的线程将最多保留60s

*

* @param corePoolSize 初始线程池大小

* @param maximumPoolSize 最大线程池大小

* @return {@link ThreadPoolExecutor}

*/

public static ThreadPoolExecutor newExecutor(int corePoolSize, int maximumPoolSize) {

return ExecutorBuilder.create().setCorePoolSize(corePoolSize).setMaxPoolSize(maximumPoolSize).build();

}

/**

* 获得一个新的线程池

* 传入阻塞系数,线程池的大小计算公式为:CPU可用核心数 / (1 - 阻塞因子)

* Blocking Coefficient(阻塞系数) = 阻塞时间/(阻塞时间+使用CPU的时间)

* 计算密集型任务的阻塞系数为0,而IO密集型任务的阻塞系数则接近于1。

*

* see: http://blog.csdn.net/partner4java/article/details/9417663

*

* @param blockingCoefficient 阻塞系数,阻塞因子介于0~1之间的数,阻塞因子越大,线程池中的线程数越多。

* @return {@link ThreadPoolExecutor}

* @since 3.0.6

*/

public static ThreadPoolExecutor newExecutorByBlockingCoefficient(float blockingCoeffi

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值