线程池使用

本文深入探讨Java中的线程池,介绍其工作原理、常见类型及配置参数,结合实例阐述如何有效利用线程池提升并发性能,降低资源消耗。通过学习,读者将能掌握如何在实际开发中合理使用线程池。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

# 1. 创建线程池

public final class TaskPoolManager {

    /** 默认线程池核心线程数.
     *
     */
    static final int DEFAULT_CORE_POOL_SIZE = 16;

    /** 默认线程池最大允许线程数.
     *
     */
    static final int DEFAULT_MAX_POOL_SIZE = 30;

    /** 默认线程池中空闲线程的存活时间.
     * 30 s
     */
    static final long DEFAULT_KEEP_ALIVE_TIME = 30000L;

    /** 默认线程池中等待队列中允许等待的最大线程数.
     *  按照3小时切分,一天8个任务,一个月240个任务,当前队列设置3个月线程数
     */
    static final int DEFAULT_WAIT_QUEUE_SIZE = 720;

    /** 线程池.
     * 采用固定长度的阻塞队列,同时使用 CallerRunsPolicy 拒绝策略
     * 当阻塞队列无法再加入新任务时,将任务交给提交任务的线程执行,也就是谁提交任务,谁就负责执行任务
     */
    private static ThreadPoolExecutor pool = new ThreadPoolExecutor(
            DEFAULT_CORE_POOL_SIZE, DEFAULT_MAX_POOL_SIZE,
            DEFAULT_KEEP_ALIVE_TIME, TimeUnit.MILLISECONDS,
            new ArrayBlockingQueue<Runnable>(DEFAULT_WAIT_QUEUE_SIZE),
            new ThreadPoolExecutor.CallerRunsPolicy());

    /** 私有化构造
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值