1

外部工具给我带来了麻烦。有没有办法在不使用一些外部 gui 工具的情况下获得每个函数的简单 cpu 使用/时间?

我一直在尝试使用 VisualVM 来分析我的 java 程序,但是我遇到了可怕的、令人心碎的、野心勃勃的结果。它只会显示堆使用情况,我感兴趣的是 CPU 使用情况,但该面板仅显示此 JVM 不支持。顺便说一下,没有告诉我要使用哪个 JVM。我已经下载了 JDK 6 并使用它启动了它,我确保我的程序针对同一个虚拟机,但什么也没有!还是一样,无用的错误消息。我的需求很简单。我只是想找出程序在哪里花费时间。Python 有一个出色的内置分析器,可以打印出每个函数花费的时间,包括每次调用和总时间格式。这就是我现在正在寻找的范围。有人有什么建议吗?

4

1 回答 1

2

这不是很漂亮,但是您可以通过在命令行中添加一个开关来使用内置的 hprof 分析机制。

-Xrunhprof:cpu=times

有很多选择;有关详细信息,请参阅HPROF的 Oracle 文档页面。

因此,例如,如果您有一个想要分析的可执行 jar,您可以键入:

java -Xrunhprof:cpu=times -jar Hello.jar

运行完成后,您将拥有一个名为“java.hprof.txt”的(大)文本文件。

该文件将包含一堆有趣的数据,但您要查找的部分是开始的部分:

CPU TIME (ms) BEGIN (total = 500) Wed Feb 27 16:03:18 2013
rank   self  accum   count trace method
   1  8.00%  8.00%    2000 301837 sun.nio.cs.UTF_8$Encoder.encodeArrayLoop
   2  5.40% 13.40%    2000 301863 sun.nio.cs.StreamEncoder.writeBytes
   3  4.20% 17.60%    2000 301844 sun.nio.cs.StreamEncoder.implWrite
   4  3.40% 21.00%    2000 301836 sun.nio.cs.UTF_8.updatePositions

或者,如果您还没有这样做,我会尝试安装 VisualVM-Extensions、VisualGC、Threads Inspector,以及至少 Swing、JVM、Monitor 和 Jvmstat Tracer Probes。

转到工具-> 插件来安装它们。如果您需要更多详细信息,请发表评论,我将进一步扩展此答案。

于 2013-02-27T21:16:19.920 回答