timingthreadpool.java

来自「java concurrency in practice 源码. JAVA」· Java 代码 · 共 53 行

JAVA
53
字号
package net.jcip.examples;import java.util.concurrent.*;import java.util.concurrent.atomic.*;import java.util.logging.*;/** * TimingThreadPool * <p/> * Thread pool extended with logging and timing * * @author Brian Goetz and Tim Peierls */public class TimingThreadPool extends ThreadPoolExecutor {    public TimingThreadPool() {        super(1, 1, 0L, TimeUnit.SECONDS, null);    }    private final ThreadLocal<Long> startTime = new ThreadLocal<Long>();    private final Logger log = Logger.getLogger("TimingThreadPool");    private final AtomicLong numTasks = new AtomicLong();    private final AtomicLong totalTime = new AtomicLong();    protected void beforeExecute(Thread t, Runnable r) {        super.beforeExecute(t, r);        log.fine(String.format("Thread %s: start %s", t, r));        startTime.set(System.nanoTime());    }    protected void afterExecute(Runnable r, Throwable t) {        try {            long endTime = System.nanoTime();            long taskTime = endTime - startTime.get();            numTasks.incrementAndGet();            totalTime.addAndGet(taskTime);            log.fine(String.format("Thread %s: end %s, time=%dns",                    t, r, taskTime));        } finally {            super.afterExecute(r, t);        }    }    protected void terminated() {        try {            log.info(String.format("Terminated: avg time=%dns",                    totalTime.get() / numTasks.get()));        } finally {            super.terminated();        }    }}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?