gpt4 book ai didi

Java 堆充满了 java Finalize() 调用

转载 作者:行者123 更新时间:2023-12-01 12:25:05 24 4
gpt4 key购买 nike

我的应用程序在两种环境中运行良好,但在验收测试环境中存在内存泄漏。 JVM 堆转储显示堆已占 java.object.finalize() 的 98%(如果我没记错的话)。GC 日志表明 GC 越来越频繁地执行 Full GC,直到 JVM 给出 Out of Memory 错误。

这可能是什么原因造成的?所有环境中的应用程序都是相同的,但问题环境中的操作系统和网络略有不同。 Java 在所有环境中都是相同的。这个输出到底意味着什么,GC 已调用 Object Finalize() 但由于某种原因它没有完成?我正在使用 JBoss EAP 5。

最佳答案

有可能创建需要比最终确定更快的速度完成的垃圾。当一个对象被确定为不可访问(即符合收集条件)并且需要终结时,它将被添加到终结器队列中,而不是立即被收集。在终结器完成后的下一次 GC 中,可以收集该对象。换句话说,终结会延迟内存的恢复。

有一个线程执行所有 Finalize 方法,默认情况下它与所有其他线程以相同的优先级运行。如果您有许多线程创建需要终结的垃圾,那么它们产生垃圾的速度比一个终结器线程执行 finalize() 方法的速度要快。另外,如果你的终结方法速度不快,你只会让这个问题变得更糟。

总而言之,您可能需要执行太多和/或太慢的 finalize() 方法。在单一问题环境中,最终确定方法可能会更慢?或者你有更多的处理能力,所以你可以更快地产生垃圾?

我以前也遇到过这个问题。为了缓解这个问题,我提高了终结器线程的优先级。这样做的技巧是在初始化期间创建一 block 垃圾,覆盖 Finalize() 并在终结期间更改当前线程中的线程优先级。在这种情况下,更改终结器线程的优先级足以解决问题,但不能保证能够解决问题。

关于Java 堆充满了 java Finalize() 调用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26425956/

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