本文介绍: 在这个例子中,我们创建了一个线程池,并提交了10个任务给线程池执行。线程空闲时间是非核心线程在空闲状态下被保留的时间,超过这个时间就会被销毁,直到线程数达到核心线程数为止。核心线程数是线程池中一直存活的线程数量,即使它们处于空闲状态也不会被销毁。拒绝策略定义了当任务无法被接受时的处理方式,例如抛出异常、丢弃任务等。线程工厂用于创建新的线程,可以自定义线程的名称、优先级等属性。最大线程数是线程池中允许的最大线程数量,包括活动和空闲线程。时间单位用于指定线程空闲时间的单位,可以是秒、毫秒等。
1. 线程池的基本概念
线程池由以下几个主要组件构成:
- 任务队列(Task Queue): 用于存储等待执行的任务。
- 工作线程池: 用于执行任务的线程集合。
- 线程工厂(Thread Factory): 用于创建新线程的工厂。
- 拒绝策略(Rejected Execution Handler): 定义了当任务被拒绝时的处理策略。
2. 线程池的参数
2.1 核心线程数(Core Pool Size)
核心线程数是线程池中一直存活的线程数量,即使它们处于空闲状态也不会被销毁。
2.2 最大线程数(Maximum Pool Size)
最大线程数是线程池中允许的最大线程数量,包括活动和空闲线程。
2.3 线程空闲时间(Keep Alive Time)
线程空闲时间是非核心线程在空闲状态下被保留的时间,超过这个时间就会被销毁,直到线程数达到核心线程数为止。
2.4 时间单位(Time Unit)
2.5 任务队列(Blocking Queue)
2.6 线程工厂(Thread Factory)
线程工厂用于创建新的线程,可以自定义线程的名称、优先级等属性。
2.7 拒绝策略(Rejected Execution Handler)
拒绝策略定义了当任务无法被接受时的处理方式,例如抛出异常、丢弃任务等。
3. 拒绝策略
3.1 AbortPolicy
抛出RejectedExecutionException
异常,默认策略。
ThreadPoolExecutor executor = new ThreadPoolExecutor(
corePoolSize,
maximumPoolSize,
keepAliveTime,
timeUnit,
blockingQueue,
threadFactory,
new ThreadPoolExecutor.AbortPolicy()
);
3.2 CallerRunsPolicy
ThreadPoolExecutor executor = new ThreadPoolExecutor(
corePoolSize,
maximumPoolSize,
keepAliveTime,
timeUnit,
blockingQueue,
threadFactory,
new ThreadPoolExecutor.CallerRunsPolicy()
);
3.3 DiscardOldestPolicy
ThreadPoolExecutor executor = new ThreadPoolExecutor(
corePoolSize,
maximumPoolSize,
keepAliveTime,
timeUnit,
blockingQueue,
threadFactory,
new ThreadPoolExecutor.DiscardOldestPolicy()
);
3.4 DiscardPolicy
直接丢弃被拒绝的任务。
ThreadPoolExecutor executor = new ThreadPoolExecutor(
corePoolSize,
maximumPoolSize,
keepAliveTime,
timeUnit,
blockingQueue,
threadFactory,
new ThreadPoolExecutor.DiscardPolicy()
);
4. 完整示例
import java.util.concurrent.*;
public class ThreadPoolExample {
public static void main(String[] args) {
int corePoolSize = 2;
int maximumPoolSize = 5;
long keepAliveTime = 1;
TimeUnit timeUnit = TimeUnit.SECONDS;
BlockingQueue<Runnable> blockingQueue = new LinkedBlockingQueue<>();
ThreadFactory threadFactory = Executors.defaultThreadFactory();
RejectedExecutionHandler rejectedExecutionHandler = new ThreadPoolExecutor.AbortPolicy();
ThreadPoolExecutor executor = new ThreadPoolExecutor(
corePoolSize,
maximumPoolSize,
keepAliveTime,
timeUnit,
blockingQueue,
threadFactory,
rejectedExecutionHandler
);
// 提交任务给线程池
for (int i = 0; i < 10; i++) {
final int taskIndex = i;
executor.execute(() -> {
System.out.println("Thread: " + Thread.currentThread().getName() + ", executing task " + taskIndex);
try {
Thread.sleep(2000); // 模拟任务执行时间
} catch (InterruptedException e) {
e.printStackTrace();
}
});
}
// 关闭线程池
executor.shutdown();
}
}
在这个例子中,我们创建了一个线程池,并提交了10个任务给线程池执行。可以根据实际需要调整线程池的参数和拒绝策略。
原文地址:https://blog.csdn.net/weixin_54563083/article/details/134814660
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_45204.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。