6.2 線程池的擴展beforeExecute和afterExecute參數說明和使用示例

線程池ThreadPoolExecutor爲了提供擴展,提供了protected的兩個方法beforeExecute和 afterExecute,每個任務執行前後都會調用這兩個方法,相當於對線程任務的執行做了一個切面

線程池中定義的兩個空方法

public class ThreadPoolExecutor extends AbstractExecutorService {
    /**     
     * @param t 執行任務的線程
     * @param r 將要被執行的任務
     */
    protected void beforeExecute(Thread t, Runnable r) { }

    /**
     * @param r 將要被執行的任務
     * @param t 異常信息
     */
    protected void afterExecute(Runnable r, Throwable t) { }
}

測試示例

public class MyThreadPoolExpand {
    static class Customer extends Thread{
        private String name;
        private Random random = new Random();
        public Customer(String name){
            this.name = name;
        }
        @Override
        public void run() {
            System.out.println(this.name+":加入線程池");
            try {
                Thread.sleep(random.nextInt(100)*6);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }

    public static void main(String[] args) {
        ThreadPoolExecutor poolExecutor = new ThreadPoolExecutor(2,4,5,
                TimeUnit.SECONDS,new ArrayBlockingQueue<>(9),new ThreadPoolExecutor.DiscardOldestPolicy()){
            /**
             *
             * @param t   執行任務的線程
             * @param r 將要被執行的任務
             */
            @Override
            protected void beforeExecute(Thread t, Runnable r) {
                System.out.println(((Customer)r).name + ":beforeExecute將要被執行");
            }

            @Override
            protected void afterExecute(Runnable r, Throwable t) {
                System.out.println(((Customer)r).name + ":afterExecute已經執行完畢");

            }
        };
        for (int i = 0; i < 10; i++) {
            poolExecutor.execute(new Customer("customer-"+i));
        }
        poolExecutor.shutdown();
    }
}

結果:

D:\install\jdk8\bin\java.exe "-javaagent:D:\install\intellij2019\IntelliJ IDEA 2019.1.3\lib\idea_rt.jar=6496:D:\install\intellij2019\IntelliJ IDEA 2019.1.3\bin" -Dfile.encoding=UTF-8 -classpath D:\install\jdk8\jre\lib\charsets.jar;D:\install\jdk8\jre\lib\deploy.jar;D:\install\jdk8\jre\lib\ext\access-bridge-64.jar;D:\install\jdk8\jre\lib\ext\cldrdata.jar;D:\install\jdk8\jre\lib\ext\dnsns.jar;D:\install\jdk8\jre\lib\ext\jaccess.jar;D:\install\jdk8\jre\lib\ext\jfxrt.jar;D:\install\jdk8\jre\lib\ext\localedata.jar;D:\install\jdk8\jre\lib\ext\nashorn.jar;D:\install\jdk8\jre\lib\ext\sunec.jar;D:\install\jdk8\jre\lib\ext\sunjce_provider.jar;D:\install\jdk8\jre\lib\ext\sunmscapi.jar;D:\install\jdk8\jre\lib\ext\sunpkcs11.jar;D:\install\jdk8\jre\lib\ext\zipfs.jar;D:\install\jdk8\jre\lib\javaws.jar;D:\install\jdk8\jre\lib\jce.jar;D:\install\jdk8\jre\lib\jfr.jar;D:\install\jdk8\jre\lib\jfxswt.jar;D:\install\jdk8\jre\lib\jsse.jar;D:\install\jdk8\jre\lib\management-agent.jar;D:\install\jdk8\jre\lib\plugin.jar;D:\install\jdk8\jre\lib\resources.jar;D:\install\jdk8\jre\lib\rt.jar;F:\享學\2、第二期課程\(01)併發編程——mark老師\10-2019.05.12-併發編程第十節課\vip-v2-concurrent\concurrent\target\classes;D:\install\maven\maven-repository\commons-lang\commons-lang\2.6\commons-lang-2.6.jar;D:\install\maven\maven-repository\io\netty\netty-all\4.1.28.Final\netty-all-4.1.28.Final.jar cn.enjoyedu.ch6.MyThreadPoolExpand
customer-1:beforeExecute將要被執行
customer-0:beforeExecute將要被執行
customer-0:加入線程池
customer-1:加入線程池
customer-0:afterExecute已經執行完畢
customer-2:beforeExecute將要被執行
customer-2:加入線程池
customer-2:afterExecute已經執行完畢
customer-3:beforeExecute將要被執行
customer-3:加入線程池
customer-1:afterExecute已經執行完畢
customer-4:beforeExecute將要被執行
customer-4:加入線程池
customer-3:afterExecute已經執行完畢
customer-5:beforeExecute將要被執行
customer-5:加入線程池
customer-4:afterExecute已經執行完畢
customer-6:beforeExecute將要被執行
customer-6:加入線程池
customer-6:afterExecute已經執行完畢
customer-7:beforeExecute將要被執行
customer-7:加入線程池
customer-7:afterExecute已經執行完畢
customer-8:beforeExecute將要被執行
customer-8:加入線程池
customer-8:afterExecute已經執行完畢
customer-9:beforeExecute將要被執行
customer-9:加入線程池
customer-5:afterExecute已經執行完畢
customer-9:afterExecute已經執行完畢

Process finished with exit code 0

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章