java – Finalized在4 g中拥有大量内存2.5 gig
发布时间:2020-12-15 00:36:27 所属栏目:Java 来源:网络整理
导读:我已经阅读了很多关于终结器如何工作的文章以下是我的理解:如果一个类已经实现了finalize方法,那么Jvm会在该对象上创建一个Finalizer实例作为监视狗. 当GC运行时,它会标记要处置的对象并将它们添加到引用队列中,然后终结器线程将从队列中选择这些对象并执行
我已经阅读了很多关于终结器如何工作的文章以下是我的理解:如果一个类已经实现了finalize方法,那么Jvm会在该对象上创建一个Finalizer实例作为监视狗.
当GC运行时,它会标记要处置的对象并将它们添加到引用队列中,然后终结器线程将从队列中选择这些对象并执行它们的终结方法. 我的问题是:如何从堆转储中找到对象,其终结方法由于某种原因未完成并开始堆积引用队列? 引用队列是否按特定顺序排列? 解决方法
这可能不是您正在寻找的答案,但您是否考虑过使用PhantomReference而不是覆盖finalize()?这是一个讨论它的
article.
基本的想法是,不建议依靠finalyze()方法进行预先清理,因为 >你无法预测何时会被召唤. PhantomReference提供了一种更简洁的方法来触发垃圾收集器移除对象时的操作. Object objectToHandle = new Object(); ReferenceQueue queue = new ReferenceQueue(); PhantomReference reference = new PhantomReference(objectToHandle,queue); 当垃圾收集器从内存中删除objectToHandle时,它的引用将被添加到队列中.您可以通过调用queue.remove()来检测这一点,然后执行清理操作. // will block until a reference becomes available Reference removedRef = queue.remove(); //.. you can now perform clean-up actions 注意:PhantomReference.get()始终返回null,因此在从内存中删除对象后,无法将其恢复. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |