gpt4 book ai didi

java - 线程创建和同步所需的时间

转载 作者:太空宇宙 更新时间:2023-11-04 14:29:29 35 4
gpt4 key购买 nike

我试图找出线程创建和同步所需的时间。我知道我应该使用 ThreadMXBean,但我找不到使用 ThreadMXBean 和 Callable 接口(interface)演示这一点的简单示例。

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 次)的长 while 循环期间所有线程的信息。我可以使用线程转储获取所有迭代中所有线程的摘要信息吗?

最佳答案

除非您出于好奇而想知道它,否则您可能会认为线程创建时间可以忽略不计,如果您不创建过多的线程(也就是说,您正确使用 Executor 框架或执行以下操作)正确地用手操作)。

关于由于锁争用而花费的时间,它随应用程序负载而变化。获取有用信息的最佳方法是在使用您希望支持的负载加载应用程序时进行线程转储,并查找处于 BLOCKED 状态的线程和处于 RUNNABLE 状态的线程。这样您就可以了解您的程序在锁争用方面的表现如何。

关于java - 线程创建和同步所需的时间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26313407/

35 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com