gpt4 book ai didi

java - -XX :+HeapDumpOnOutOfMemoryError not creating hprof file in OOM

转载 作者:搜寻专家 更新时间:2023-11-01 01:58:49 25 4
gpt4 key购买 nike

我使用以下参数(以及其他参数)开始我的 Java 代码(Vista 中的 1.6.0_16)-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=../logs。我运行代码,我可以在日志中看到有两个 OOM。

我知道的第一个是因为我可以在标准输出中看到正在创建 hprof 文件:

java.lang.OutOfMemoryError: Java heap space
Dumping heap to ../logs\java_pid4604.hprof ...
Heap dump file created [37351818 bytes in 1.635 secs]

然后,在代码末尾,我得到了另一个 OOM,我捕获了它,但我没有创建第二个 hprof 文件。有谁知道这是为什么??是不是我捕捉到了OOM异常?

最佳答案

我不会尝试从 OutOfMemoryError 中恢复,因为某些对象可能最终处于未定义状态(例如,只是考虑一个无法分配其数组来存储日期的 ArrayList)。

关于您的问题,我怀疑 -XX:+HeapDumpOnOutOfMemoryError 只是故意创建一个转储以防止多个堆转储:只需考虑多个线程同时抛出 OOME,每次抛出都会导致堆转储异常。

总结:不要尝试从 OOME 中恢复,也不要期望 JVM 写入的不仅仅是一个堆转储。但是,如果您仍然觉得需要生成堆转储,您可以尝试手动处理 OOME 异常并调用 jmap 来创建转储或使用“-XX:+HeapDumpOnCtrlBreak”(但不确定如何以编程方式模拟 CtrlBreak) .

关于java - -XX :+HeapDumpOnOutOfMemoryError not creating hprof file in OOM,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1518839/

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