当线程被执行时,你会如何检索线程的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();
}
}