ThreadPoolExecutor小记

阿里要求在创建线程池时 不能使用 Excutors,而要使用ThreadPoolExecutor,具体描述如下:

这里写图片描述

故研究了一下ThreadPoolExecutor,得出的一点小结论记录如下:

ThreadPoolExecutor的构造方法:

public ThreadPoolExecutor(int corePoolSize,
                              int maximumPoolSize,
                              long keepAliveTime,
                              TimeUnit unit,
                              BlockingQueue<Runnable> workQueue) {}

当提交的线程小于corePoolSize时,创建新线程来启动
如果提交线程数大于corePoolSize时,将线程加入workQueue中,如果workQueue满了,则继续创建新线程直到线程数等于maximumPoolSize,此时再提交新的线程,则抛出java.util.concurrent.RejectedExecutionException异常

ThreadPoolExecutor threadPoolExecutor = new ThreadPoolExecutor(corePoolSize,
            maximumPoolSize, 0L, TimeUnit.SECONDS, new MyBlockingQueue(queueSize));

上述代码中maximumPoolSize>=corePoolSize,否则会抛出java.lang.IllegalArgumentException异常

  • 若提交n个线程(0<=n<=corePoolSize),则线程池创建n个线程并执行
  • 若提交n(corePoolSize < n<=corePoolSize+queueSize),则前corePoolSize个提交的线程直接被创建运行,( n-corePoolSize )个线程加入workQueue中等待执行
  • 若提交n(corePoolSize+queueSize < n<=maximumPoolSize+queueSize , corePoolSize < maximumPoolSize)则前corePoolSize个提交的线程直接被创建运行,( n-corePoolSize
    )个线程加入workQueue中等待执行,(n-corePoolSize-queueSize)再创建新的线程来执行

测试代码

import java.util.concurrent.LinkedBlockingQueue;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;

/**
 * @author ElinZhou
 * @version $Id: ThreadPoolTest.java , v 0.1 2017/1/10 10:33 ElinZhou Exp $
 */
public class ThreadPoolTest {

    public static void main(String... args) throws Exception {

        ThreadPoolExecutor threadPoolExecutor = new ThreadPoolExecutor(5, 6, 0L,
            TimeUnit.SECONDS, new MyBlockingQueue(1));
        int nThread = 8;

        for (int i = 0; i < nThread; i++) {
            System.out.println("create thread " + i);
            Thread thread = new Thread(new MyRunnable(i));
            threadPoolExecutor.submit(thread);
        }

        //        TimeUnit.SECONDS.sleep(5);

    }

}

class MyBlockingQueue extends LinkedBlockingQueue<Runnable> {
    public MyBlockingQueue() {
        super();
    }

    public MyBlockingQueue(int nThread) {
        super(nThread);
    }

    @Override
    public boolean offer(Runnable runnable) {
        System.out.println("invoke offer method:" + runnable);
        return super.offer(runnable);
    }
}

class MyRunnable implements Runnable {

    private int id;

    public MyRunnable(int id) {
        this.id = id;
    }

    @Override
    public void run() {
        System.out.println(id + " start at:" + System.currentTimeMillis());
        try {
            Thread.sleep(500);
        } catch (InterruptedException e) {
            System.out.println(id + " interrupted at:" + System.currentTimeMillis());
        }
        System.out.println("------" + id + " end at:" + System.currentTimeMillis());

    }

    @Override
    public String toString() {
        return "MyRunnable-" + id;
    }
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值