在执行和完成时检索线程 ID?爪哇岛



当线程被执行时,你会如何检索线程的id,然后在它完成时再次检索。

从而从主线程中按执行/完成的顺序打印它们。

我正在使用叉连接池并执行可调用类。

谢谢

您应该在任务类中添加如下内容:

executorService.submit(new Runnable() {
            @Override
            public void run() {
                System.out.println("Running task in" + Thread.currentThread().getId());
                <your code>
                System.out.println("Finished task in" + Thread.currentThread().getId());
            }
        });

创建实现Callable并在内部调用另一个可调用对象的包装器。但也检索线程 ID 并使用它做你想要的事情,例如:

class ThreadTrackingCallable<V> implements Callable<V> {
    private Callable<V> payload;
    ThreadTrackingCallable(Callable<V> payload) {
        this.payload = payload;
    }
    V call() throws Exception {
       jobStarted(getCurrentThreadId());
       V result = payload.call();
       jobEnded(getCurrentThreadId());
       return result;
    }
    private int getCurrentThreadId() {
        return Thread.currentThread().getId();
    }
}

最新更新