Java并发编程——线程池的使用(三)线程池执行任务、取消任务

一、线程池执行Runnable任务

executor.execute(runnable)
        executor.execute(new Runnable() {
            @Override
            public void run() {
                System.out.println("执行任务");
            }
        });

log:

12-25 11:13:00.260 8710-8860/lbx.myapplication I/System.out: 执行任务

二、线程池取消任务,shutdown和shutdownNow

        线程池取消任务的方法有两种:shutDown()方法和shutDownNow()方法。

2.1  shutdown的使用

先看段代码,栗子1:

public static void main(String[] args) {

        ThreadPoolExecutor executor = new ThreadPoolExecutor(
                5,
                10,
                60,
                TimeUnit.SECONDS, new LinkedBlockingQueue<Runnable>(),
                new MyThread(),
                new ThreadPoolExecutor.AbortPolicy());
        executor.execute(new Runnable() {
            @Override
            public void run() {
                System.out.println("执行任务");
            }
        });
        //调用shutdown方法
        executor.shutdown();
        //再次添加任务
        executor.execute(new Runnable() {
            @Override
            public void run() {
                System.out.println("执行任务2");
            }
        });
    }

log:

12-25 14:35:20.810 6807-7022/lbx.myapplication I/System.out: 执行任务
Caused by: java.util.concurrent.RejectedExecutionException······

        log里抛出了异常:
RejectedExecutionException,因为我们的拒绝策略是
ThreadPoolExecutor.AbortPolicy,线程池
shutdown后就不可以再添加新任务了。

        这里大家可以再用不同的拒绝策略,自己打印log自己试一下,篇幅有限,我就不在这里一个一个试了。

栗子2:

public static void main(String[] args) {

        ThreadPoolExecutor executor = new ThreadPoolExecutor(
                5,
                10,
                60,
                TimeUnit.SECONDS, new LinkedBlockingQueue<Runnable>(),
                new MyThread(),
                new ThreadPoolExecutor.AbortPolicy());
        for (int i = 0; i < 10; i++) {
            final int finalI = i;
            executor.execute(new Runnable() {
                @Override
                public void run() {
                    try {
                        System.out.println("第" + finalI);
                        Thread.sleep(500);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }
            });
        }
        try {
            Thread.sleep(300);
            //在主线程调用shutdown
            executor.shutdown();
            System.out.println("已经shutdown了");
            } catch (InterruptedException e) {
           e.printStackTrace();
           } 
}

log:

12-25 15:02:19.130 11997-12132/lbx.myapplication I/System.out: 第0
12-25 15:02:19.130 11997-12134/lbx.myapplication I/System.out: 第2
12-25 15:02:19.130 11997-12133/lbx.myapplication I/System.out: 第1
12-25 15:02:19.130 11997-12135/lbx.myapplication I/System.out: 第3
12-25 15:02:19.130 11997-12136/lbx.myapplication I/System.out: 第4
12-25 15:02:19.430 11997-11997/lbx.myapplication I/System.out: 已经shutdown了
12-25 15:02:19.630 11997-12132/lbx.myapplication I/System.out: 第5
12-25 15:02:19.630 11997-12134/lbx.myapplication I/System.out: 第6
12-25 15:02:19.630 11997-12133/lbx.myapplication I/System.out: 第7
12-25 15:02:19.630 11997-12135/lbx.myapplication I/System.out: 第8
12-25 15:02:19.630 11997-12136/lbx.myapplication I/System.out: 第9

        跟之前的栗子1做对比我们发现,调用shutdown只是拒绝向队列里添加任务,而已经在队列里的任务,扔会继续执行

2.2  shutdownNow的使用

        栗子3:

        继续用栗子1的代码就好,不同的是,把shutdown改成shutdownNow,其他地方不变,所以我就不上代码了,log也是一样的,仍然执行第一个任务,然后抛出异常RejectedExecutionException。

        栗子4:同样的,继续用栗子2的代码就好,不同的是,把shutdown改成shutdownNow,其他地方不变,执行代码,看log:

12-25 15:30:57.560 2251-2424/lbx.myapplication I/System.out: 第0
12-25 15:30:57.560 2251-2425/lbx.myapplication I/System.out: 第1
12-25 15:30:57.560 2251-2426/lbx.myapplication I/System.out: 第2
12-25 15:30:57.560 2251-2428/lbx.myapplication I/System.out: 第4
12-25 15:30:57.570 2251-2427/lbx.myapplication I/System.out: 第3
12-25 15:30:57.860 2251-2251/lbx.myapplication I/System.out: 已经shutdownNow了

        我们发现,调用shutdownNow后,这时线程池所执行的任务停止了,当然,新添加任务也是会被拒绝的,所以,
shutdownNow会立刻停止所有正在执行的任务,并且队列不接受新的任务


版权声明:本文为h610968110原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
THE END
< <上一篇
下一篇>>