线程拾遗

2018-12-27  本文已影响6人  Tomy_Jx_Li

最近有被问到线程池创建之后,线程的数量是如何变化的,所以就想画个图来表示

线程数量变化(也就是线程池启动之后的线程数量变化)

最初学习线程池的时候,自己手动创建线程的时候就是常见5个10个的线程,所以就想着线程池一开始的时候直接创建完毕,然后就是等待有用户的需求了。但是今天亲自测试了下,发现跟自己理解的有点出入。
测试环境:jdk1.7,jdk1.8
测试代码

 public static void main(String[] args) throws InterruptedException {
        final AtomicInteger counter = new AtomicInteger();
        final ThreadGroup group = new ThreadGroup("test-xiancheng");

        class Task implements Runnable{

            private volatile boolean stop = false;

            @Override
            public void run() {
                while (!stop) {

                }
            }
        }

        ThreadPoolExecutor executor = new ThreadPoolExecutor(
                3,
                6,
                0,
                TimeUnit.MILLISECONDS,
                new ArrayBlockingQueue<Runnable>(2),
                new ThreadFactory() {
                    @Override
                    public Thread newThread(Runnable r) {
                        return new Thread(group, r, "test-test-" + counter.getAndIncrement(), 0);
                    }
                },
                // 使用AbortPolicy测试拒绝策略较合适,直接抛异常,可以直接看到,但是不能执行后续代码
                // new ThreadPoolExecutor.AbortPolicy()
                new ThreadPoolExecutor.DiscardPolicy()
        );
        Task task = new Task();
        for (int i = 0; i < 16; i++) {
            executor.execute(task);
        }

        TimeUnit.SECONDS.sleep(15);
        task.stop = true;
    }

利用断点干预,同时使用jstack查看线程快照,找出创建的线程。得出如下图的结论:


线程池创建之后线程数量变化图

要点:

上一篇下一篇

猜你喜欢

热点阅读