java笔记-ThreadPoolExecutor

2018-07-28  本文已影响11人  一个喜欢烧砖的人

为什么用线程池

有时候,系统需要处理非常多的执行时间很短的请求,如果每一个请求都开启一个新线程的话,系统就要不断的进行线程的创建和销毁,有时花在创建和销毁线程上的时间会比线程真正执行的时间还长。而且当线程数量太多时,系统不一定能受得了。

使用线程池主要为了解决一下几个问题:

Executor

注意:不同于Executors(类)
Executor是一个接口,跟线程池有关的基本都要跟他打交道。下面是常用的ThreadPoolExecutor的关系。

线程池规则验证

下面都假设任务队列没有大小限制
任务队列大小有限时

图:

image.png

代码验证

所有任务

        /**
         * 所有的任务
         */
        Runnable runnable = new Runnable() {
            public void run() {
                try {
                    Thread.sleep(2000);
                    System.out.println(Thread.currentThread().getName() + "is runing....");
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        };

验证示例

ThreadPoolExecutor executor = new ThreadPoolExecutor(6, 10, 5, TimeUnit.SECONDS, new SynchronousQueue<Runnable>());
executor.execute(runnable);
        executor.execute(runnable);
        executor.execute(runnable);

        System.out.println("---先开三个---");
        System.out.println("核心线程数:" + executor.getCorePoolSize());
        System.out.println("线程池数:" + executor.getPoolSize());
        System.out.println("队列任务数" + executor.getQueue().size());

        executor.execute(runnable);
        executor.execute(runnable);
        executor.execute(runnable);

        System.out.println("---再开三个---");
        System.out.println("核心线程数:" + executor.getCorePoolSize());
        System.out.println("线程池数:" + executor.getPoolSize());
        System.out.println("队列任务数" + executor.getQueue().size());

        Thread.sleep(8000);

        System.out.println("---8秒之后再来三个---");
        System.out.println("核心线程数:" + executor.getCorePoolSize());
        System.out.println("线程池数:" + executor.getPoolSize());
        System.out.println("队列任务数" + executor.getQueue().size());
上一篇下一篇

猜你喜欢

热点阅读