使用带调试的 IntelliJ 在 VisualVm 中进行分析
Profiling in VisualVm Using IntelliJ with Debug
我想分析由 IntelliJ 启动的测试应用程序。对于分析,我使用 VisualVm。
我使用参数 -J-Dorg.netbeans.profiler.separateConsole=true
启动了 java 工具。
我使用 VM 参数 -Xverify:none
启动了应用程序,否则如果我开始分析,VisualVM 会抛出错误(重新定义失败,错误 62)
我想在执行任何重要代码之前分析我的应用程序,因此我尝试设置一个断点并开始在 VisualVM 中进行分析。问题是当我在断点等待时,VisualVm 不响应任何交互。我错过了什么吗?
在正常执行(不调试)中,我的程序等待输入,所以我可以在不调试的情况下分析它。但是,如果一个程序没有这样的 "waiting points" 怎么办?
我的测试应用程序如下所示:
package my.visualvm.example;
import java.util.Scanner;
public class MainClass {
public static void main(String[] args) {
System.out.println("Starting Application: " + MainClass.class.getSimpleName());
Scanner scanner = new Scanner(System.in);
while (scanner.hasNext()) {
double value = scanner.nextDouble();
if (value == 0d) {
break;
}
System.out.println(Powa.powaPowa(value));
}
System.out.println("Stopping Application: " + MainClass.class.getSimpleName());
}
}
其他class:
package my.visualvm.example;
final class Powa {
private Powa() {
}
static double powaPowa(double powa) {
return Math.pow(powa, 2);
}
}
设置断点只挂起当前线程。
我想分析由 IntelliJ 启动的测试应用程序。对于分析,我使用 VisualVm。
我使用参数 -J-Dorg.netbeans.profiler.separateConsole=true
启动了 java 工具。
我使用 VM 参数 -Xverify:none
启动了应用程序,否则如果我开始分析,VisualVM 会抛出错误(重新定义失败,错误 62)
我想在执行任何重要代码之前分析我的应用程序,因此我尝试设置一个断点并开始在 VisualVM 中进行分析。问题是当我在断点等待时,VisualVm 不响应任何交互。我错过了什么吗?
在正常执行(不调试)中,我的程序等待输入,所以我可以在不调试的情况下分析它。但是,如果一个程序没有这样的 "waiting points" 怎么办?
我的测试应用程序如下所示:
package my.visualvm.example;
import java.util.Scanner;
public class MainClass {
public static void main(String[] args) {
System.out.println("Starting Application: " + MainClass.class.getSimpleName());
Scanner scanner = new Scanner(System.in);
while (scanner.hasNext()) {
double value = scanner.nextDouble();
if (value == 0d) {
break;
}
System.out.println(Powa.powaPowa(value));
}
System.out.println("Stopping Application: " + MainClass.class.getSimpleName());
}
}
其他class:
package my.visualvm.example;
final class Powa {
private Powa() {
}
static double powaPowa(double powa) {
return Math.pow(powa, 2);
}
}
设置断点只挂起当前线程。