9

VisualVM用来查看我的应用程序在哪里运行缓慢。但它没有显示所有方法,可能没有显示延迟应用程序的所有方法。

我有一个实时应用程序(声音处理)并且在几百微秒内有时间不足。

是否有可能VisualVM隐藏本身快速的方法?

更新 1

我通过采样器和猜测找到了缓慢的方法。这是toString()从调试日志中调用的方法,该方法已关闭,但耗时。

Settings帮助,现在我知道如何看待它:这取决于Start profiling from选项。

4

3 回答 3

15

除了 Ryan Stewart 提到的过滤器之外,还有一些其他原因导致方法可能不会出现在分析器中:

  • 采样配置文件本质上是随机的:每 N ms 对所有线程的当前堆栈进行一次采样。一些实际执行但在运行期间未在任何示例中捕获的方法将不会出现。这通常不会有太大问题,因为它们没有出现在任何样本中,这意味着这些方法很有可能不会占用您运行时的大部分时间。
  • 在 visualvm 中使用基于检测的采样(称为“CPU 分析”)时,您需要定义分析方法的入口点(“开始分析从”选项)。我发现默认包中的方法会失败,并且在附加分析器时也不会在当前正在运行的方法中获取时间(在当前调用期间 - 它将获得以后的调用。这可能是因为在当前调用完成之前,不会交换检测方法。
  • 采样受到基于堆栈跟踪的分析的潜在严重问题的影响,即仅在代码中的安全点进行采样。当请求跟踪时,每个线程都被强制到一个安全点,然后获取堆栈。在某些情况下,您的代码中可能存在不进行安全点轮询的热点(常见于简单循环,JIT 可以保证在固定次数的迭代后终止),并与一些确实具有安全点轮询的代码交错。您的堆栈将始终在安全点代码中显示您的进程,而不是在安全点免费代码中,即使后者可能占用大部分 CPU 时间。
于 2012-12-24T21:12:10.013 回答
6

我现在没有它,但在你开始分析之前,有一个默认隐藏的设置窗格,允许你输入正则表达式来过滤掉方法。默认情况下,它会过滤掉很多核心的 JDK 内容。

于 2012-12-24T21:00:27.143 回答
0

我的宠物项目也有同样的问题。我添加了一个package名字,问题就解决了。我不明白为什么。VisualVM 1.4.1,jdk1.8.0_181jdk-10.0.2,Windows 10

于 2018-08-08T10:47:09.117 回答