ThreadPoolExecutor参数说明

[ ThreadPoolExecutor的七大参数 ]

int corePoolSize: 核心线程池大小
int maximumPoolSize: 最大的线程池大小
long keepAliveTime: 存活的时间 [ 超时了没有人使用,就释放 ]
TimeUnit unit:存活的单位
BlockingQueue< Runnable > workQueue:阻塞队列
ThreadFactory threadFactory:线程工厂–创建线程的 一般不用动
RejectedExecutionHandler handler :拒绝策略

[ ThreadPoolExecutor的四大拒绝策略 ]

AbortPolicy:满了如果还有线程进来,不处理直接抛出异常 [ java.util.concurrent.RejectedExecutionException ]
CallerRunsPolicy:哪儿来的去哪儿里,线程池不处理,最后交给了主线程处理
DiscardPolicy:队列满了不会抛出异常,任务也不会执行,直接丢弃任务
DiscardOldestPolicy: 尝试和最早的竞争,如果失败直接丢弃,成功便执行,不会抛出异常

使用

/**
     * 7大参数
     */
    public static void test(){
        //开启线程调用的 ThreadPoolExecutor

        ThreadPoolExecutor service = new ThreadPoolExecutor(2,
                                                                    5,
                                                                    3,
                                                                    TimeUnit.SECONDS,
                                                                    new LinkedBlockingDeque<>(3),
                                                                    Executors.defaultThreadFactory(),
                                                                    new ThreadPoolExecutor.DiscardOldestPolicy()
                                                            );

        /**
         *  [ ThreadPoolExecutor的七大参数 ]
         *
         * int corePoolSize,                        核心线程池大小
         * int maximumPoolSize,                     最大的线程池大小
         * long keepAliveTime,                      存活的时间 [ 超时了没有人使用,就释放 ]
         * TimeUnit unit,                           存活的单位
         * BlockingQueue<Runnable> workQueue,       阻塞队列
         * ThreadFactory threadFactory,             线程工厂--创建线程的 一般不用动
         * RejectedExecutionHandler handler         拒绝策略
         */

        /**
         *  [ ThreadPoolExecutor的四大拒绝策略 ]
         *
         * AbortPolicy                  满了如果还有线程进来,不处理直接抛出异常  [ java.util.concurrent.RejectedExecutionException ]
         * CallerRunsPolicy             哪儿来的去哪儿里,线程池不处理,最后交给了主线程处理
         * DiscardPolicy                队列满了不会抛出异常,任务也不会执行,直接丢弃任务
         * DiscardOldestPolicy          尝试和最早的竞争,如果失败直接丢弃,成功便执行,不会抛出异常
         *
         *
         */
        //获取cpu的核数
        System.err.println(Runtime.getRuntime().availableProcessors());
        try {
            for (int i = 1; i <= 9; i++) {
                service.execute(()->{
                    System.err.println(Thread.currentThread().getName()+" ok");
                });
            }
        }catch (Exception e){
            e.printStackTrace();
        }finally {
            service.shutdown();
        }

    }

cpu密集型 和 io密集型

cpu密集型
几核就是几,可以保证cpu的效率更高,System.err.println(Runtime.getRuntime().availableProcessors()); 获取cpu的核数

io密集型
判断你的程序中十分耗io的线程,程序里面有15个大型任务,io是非占用资源,至少要留15个线程处理io[ 一般预留30,也就是io程序的2倍 ]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值