- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是 JProfiler 的新手。我创建了一个非常简单的测试应用程序。这是带有 main 方法的 Main.java:
package com.example;
import java.io.IOException;
public class Main {
public static void main(String[] args) throws IOException {
Example e = new Example(); //Gets gc'ed?
System.out.println(e.getMessage());
System.in.read();
System.exit(0);
}
}
请注意,我会暂停直到按下按键。这样我确信主作用域不会结束,直到我按下一个键,所以我希望 e 存在并且不会被垃圾收集(如果这个假设不正确,请纠正我)。示例类:
package com.example;
public class Example {
public String getMessage() {
String testString = "This is the test string. Press a key to exit.";
return testString;
}
}
我使用 JProfiler Eclipse 插件启动上述应用程序。我创建了一个基于 Full Instrumentation 配置文件的 session ;我删除了 Java EE 和 JDBC 特定探针,并将其余部分保留为默认值。
现在,当探查器启动时,我进入所有对象 View ,我希望找到 com.example.* 类,但我没有找到;为什么会发生这种情况?
好吧,也许我只能在使用另一个 View (例如分配调用树)时才能找到这些对象,因此我使用 View 中的按钮启用分配记录(默认情况下禁用)。它要求我点击“计算分配”,然后弹出一个对话框。我接受默认设置,然后我看到一个空 View ,它会在永恒的空虚中自动更新。
然后我尝试了 Heap Walker。它要求我先转储。我看到一个对话框,为我提供了“选择记录对象”的选项,默认情况下未选择该选项。我将其保留为默认值,并看到一个实例计数 View 。但是,在我看到的这个类 View 中找不到我的对象。
所以我想我正在做一些根本上错误的事情;我应该怎么做才能查看我的对象,特别是我的对象的精确实例计数?
更新1:我发现了问题的一部分。当分析器窗口出现时,它会向您显示“ session 启动”对话框,您可以在其中选择配置文件并设置各种设置。第一个选项卡上有一个名为“启动”的小部分,其中有一个名为“初始录制配置文件”的设置,默认情况下设置为[无录制]。当我将其保留为默认值时,我找不到示例对象。当我将其设置为“CPU 记录”时,我可以在“所有对象” View 中找到我的示例对象。
更新2:我在 Heap Walker 中找不到该对象。当我在“所有对象” View 中选择 com.example.Example 时,我可以右键单击该对象并选择(在 Heap Walker 中显示对象)。当我这样做时,Heap Walker 告诉我堆上没有这样的对象!给出了什么?
更新3:com.example.Example 对象似乎有时会出现,有时则不会。我不明白为什么。此外,当它出现时,它将从“所有对象” View 中消失,即使主循环尚未退出,即使 com.example.Example 对象应该仍然存在......
更新4:事实证明,无论 在 IBM 的 J9 JVM 上结束的范围如何,e都会被垃圾回收。请参阅我对此的回答,它修改 main 以在按键等待之后调用第二个方法,这会强制对象保持事件状态。
最佳答案
我终于真正解开了这个谜团。结果我正在运行 IBM 的 J9 VM。显然,J9 垃圾收集更加激进:如果 e 不再在主范围内使用,它将清理主范围内的 e。我已经验证 Oracle 的 JVM 不会发生这种特定行为。
长话短说:在 IBM J9 上,您不能假设对象在 block 的范围内保持事件状态。在 Oracle 的 JVM 上,至少默认情况下,直到 block 结束之后,e 才会被垃圾回收,无论 e 的进一步使用如何。
在 IBM J9 上,当您想要强制对象保持存在时,必须有它的 future 用途。为了证明这一点,我修改了 Example.java 以包含以下内容:
package com.example;
public class Example {
public String getFirstMessage() {
String firstTestString = "This is the first message: Hello!";
return firstTestString;
}
public String getSecondMessage() {
String secondTestString = "This is the second message: Goodbye!";
return secondTestString;
}
}
然后,在 main 中,我确保在等待按键 (System.in.read()) 之后调用 getSecondMessage()。这样,我们就可以确定 GC 无法在 main 作用域结束之前清理对象,因为将来有一个调用在等待,发生在用户按下一个键之后。所以 Main.java 看起来像:
package com.example;
import java.io.IOException;
public class Main {
public static void main(String[] args) throws IOException {
Example e = new Example();
System.out.println(e.getFirstMessage());
System.in.read();
System.out.println(e.getSecondMessage());
System.exit(0);
}
}
分析上述代码无论之前被认为是其中一个因素的CPU记录设置如何都将按预期工作:对象保持事件状态,因为在按下按键之前它无法被垃圾收集。 p>
关于jprofiler - 在 JProfiler 中,为什么我的对象没有显示在“所有对象” View 中?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31695214/
嗨,我是 Jprofiler 和 Linux 的新手。 我正在尝试从安装在 Windows 机器上的 Jprofiler 远程分析监控安装在 linux 机器上的 Apache Tomcat 服务器。
当使用 JProbe 进行性能分析时,您可以查看每一行特定方法所花费的时间。 JProfiler 中是否有等效的功能? 最佳答案 没有源代码 View ,您可以在其中查看每一行以及相关的时间测量值。不
考虑以下方法模板: methodA() { Print (abc); // Instruction 1 Calculate(a+b+c); // Instruction 2 Call metho
背景:我们构建了一个产品,通过注释和自定义类加载器向 Java 添加各种功能(事务、基于共享内存的对象持久性、索引和查询、基于集群的高可用性和复制)。这些功能的大部分实现都在 C++ 库中,这些库可通
我尝试将 JProfiler 与 Intellij IDEA 一起使用,但它不断抛出带有这些消息的错误对话框, Connection Error A different version of JPro
JProfiler 中的 Net IO 时间是什么意思? JProfilerguide 说以下内容,但我不知道它到底是什么意思?是花在网络上的时间还是等待网络的时间?如果网络 io 时间过长该怎么解决
当我使用 jmap 创建转储时 jmap -J-d64 -heap:format=b ${pid} 我可以在 JProfiler 中以某种方式打开生成的 heap.bin 吗? 最佳答案 显然这很简单
JProfiler 中的 Net IO 时间是什么意思? JProfilerguide 说以下内容,但我不知道它到底是什么意思?是花在网络上的时间还是等待网络的时间?如果网络 io 时间过长该怎么解决
在过去的几天里,我一直在使用 JProfiler 来分析本地运行的 Websphere 7 服务器(从 RAD8 中)。我已经使用 JProfiler 的服务器集成功能连接到 WAS 实例。 我现在想
我正在尝试分析在 ubuntu 上运行 tomcat7 的远程服务器。我已阅读多个教程,但无法运行它。 远程服务器上的 JProfiler 集成 首先我下载 jprofiler9并在远程系统上提取。
我有安装 jprofiler 的 Linux 系统。 我必须对位于同一 Linux 系统上的一台正在运行的服务器和一台客户端进行分析。我正在从客户端向服务器发送 100 多个不同的请求。 我的查询是:
我使用 CPU View 来检查性能。 有人可以建议“直接调用过滤类的方法”是什么意思吗? 我无法上传屏幕截图。 它就像这样: “91.5% -60,324ms -14inv.direct 调用过滤类
我正在 JProfiler 中运行示例程序。然后我对类遥测中的遥测行“非 cpu 分析类”感到困惑。它是指示例程序的类吗? 最佳答案 “非 CPU 分析”类是那些不包含在过滤器设置中的类。对于示例 s
我是 JProfiler 的新手。我创建了一个非常简单的测试应用程序。这是带有 main 方法的 Main.java: package com.example; import java.io.IOEx
我正在尝试在 Tomcat 和 Oracle Weblogic 上的 win64 上运行 JProfiler。运行向导后,它卡在了线上 “等待 JProfiler GUI 连接” 另一方面,GUI 正
我正在尝试分析我的 Android 应用程序。我通过安装 JProfiler 插件 IntelliJ IDEA --> Preferences --> Plugins 这是插件描述的屏幕截图: 当我尝
我的应用程序需要大约 10 GB 的 RAM 用于特定输入,而对于常规输入,大约 1 GB 就足够了。使用 JProfiler 进行更仔细的分析表明(GC 之后)相当多的内存被 java.util.*
我们在 JProfiler 7.1.1 中遇到了一个奇怪的问题,它显示给定 HTTP 请求的运行时间与通过 Firebug 或手动测试获得的运行时间完全不同 - 2.5 秒对 7.5 秒。使用默认 s
我有 WebSphere 7 应用服务器。安装了 Java VM 1.6。 Linux. Java 版本“1.6.0”Java(TM) SE 运行时环境 (build pxa6460sr10fp1-2
我正在使用调用堆栈拆分来分析单个方法调用和传递的参数。但是,我一直遇到拆分上限限制,此时调用合并在一起,并且有一个选项可以“重置拆分上限计数器”。 这是没用的,因为重新加载树会遇到相同的拆分上限并再次
我是一名优秀的程序员,十分优秀!