我试图找出线程创建和同步所需的时间。我知道我应该使用ThreadMXBean,但我找不到使用ThreadMXBean和Callable接口演示这个的简单示例。
package teststckofw;
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;
public class TestStckOfw {
public static void main(String[] args) throws ExecutionException {
int i = 0;
int processed = 0;
while (i < 10) {
Parallel parallel1 = new Parallel();
Parallel parallel2 = new Parallel();
ExecutorService exec1 = Executors.newCachedThreadPool();
List<Callable<Integer>> tasks1 = new ArrayList<>();
try {
tasks1.add(parallel1);
tasks1.add(parallel2);
try {
List<Future<Integer>> futures = exec1.invokeAll(tasks1);
int flag = 0;
for (Future<Integer> f : futures) {
Integer res = f.get();
if (res != 0) {
processed = res;
}
if (!f.isDone()) {
flag = 1;
}
}
} catch (InterruptedException e) {
e.printStackTrace();
}
} finally {
exec1.shutdown();
}
i++;
}
}
/**************************************/
static class Parallel implements Callable<Integer> {
@Override
public Integer call() throws Exception {
int a = 2 + 2; // do something...
return a;
}
}
}
编辑: 在长时间循环期间,我需要所有线程的信息,并且需要多次迭代(远远超过10次)。我可以使用线程转储获取所有迭代中所有线程的摘要信息吗?
答案 0 :(得分:0)
除非你想要出于好奇而知道它,否则你可以假设线程创建时间可以忽略不计,如果你没有创建过多的线程(也就是说,你正确地使用Executor
框架或者手工完成它正确地)。
关于因锁争用而花费的时间,它随app app一起变化。获取有用信息的最佳方法是在使用您希望支持的负载加载应用程序时进行线程转储,并查找处于BLOCKED状态的线程和处于RUNNABLE状态的线程。通过这种方式,您可以了解关于锁争用的程序有多好。