2. 线程池——自定义线程工厂、ThreadPoolExecutor方法的重写

package concurrent;

import java.util.concurrent.*;

public class C02_ExThreadpool {
	
    public static class MyTask implements Runnable{
        private String name;
        public MyTask(String name){ this.name = name; }
        public String getName() { return name; }
        @Override
        public void run() {
            System.out.println(Thread.currentThread().getId() + ":" + name);
            try{ Thread.sleep(1000);}
            catch (InterruptedException e) { e.printStackTrace(); }
        }
    }

    /**
     * .经过自定义的线程工厂能够自定义线程的状态等信息
     */
    public static class MyThreadFactory implements ThreadFactory{

        @Override
        public Thread newThread(Runnable r) {
            Thread t = new Thread(r);
//            t.setDaemon(true);  //设置为守护线程,主线程退出后自动销毁
            System.out.println("create " + t);
            return t;
        }
    }


    public static void main(String[] args) throws InterruptedException{
        /*
        *.建立线程池,并重写线程池的beforeExecute、afterExecute、terminated。
        *.这三个方法默认时空的,但咱们能够重写去作一些事情
         */
        ExecutorService es = new ThreadPoolExecutor(5, 5, 0L, TimeUnit.MICROSECONDS,
                new LinkedBlockingDeque<>(), new MyThreadFactory()) {
            @Override
            protected void beforeExecute(Thread t, Runnable r) {
                System.out.println("准备执行:" + ((MyTask)r).getName());
            }

            @Override
            protected void afterExecute(Runnable r, Throwable t) {
                System.out.println("执行完成:" + ((MyTask)r).getName());
            }

            @Override
            protected void terminated() {
                System.out.println("线程池退出");
            }
        };
        //添加任务
        for(int i=0 ; i<3 ; i++){
            es.execute(new MyTask("Task-" + i));
            Thread.sleep(10);
        }
        es.shutdown();  //发送一个信号给线程池,线程池在完成当前全部任务后关闭
    }
}

consolejava

create Thread[Thread-0,5,main]
准备执行:Task-0
11:Task-0
create Thread[Thread-1,5,main]
准备执行:Task-1
12:Task-1
create Thread[Thread-2,5,main]
准备执行:Task-2
13:Task-2
执行完成:Task-0
执行完成:Task-1
执行完成:Task-2
线程池退出
相关文章
相关标签/搜索