- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
SoftReference
和 WeakReference
真的只有在创建为实例变量时才有帮助吗?在方法范围内使用它们有什么好处吗?
另一大部分是ReferenceQueue
。除了能够跟踪哪些引用被确定为垃圾之外,Reference.enqueue()
可以用来强制注册一个对象进行垃圾回收吗?
例如,是否值得创建一个方法来占用对象中的一些大量内存资源(由强引用持有)并创建引用以将它们排入队列?
Object bigObject;
public void dispose() {
ReferenceQueue<Object> queue = new ReferenceQueue<Object>();
WeakReference<Object> ref = new WeakReference<Object>(bigObject, queue);
bigObject = null;
ref.enqueue();
}
(想象一下,在这种情况下,Object 表示一个使用大量内存的对象类型……比如 BufferedImage
之类的)
这有什么实际效果吗?或者这只是浪费代码?
最佳答案
引用队列的一个常见习语是,例如子类 WeakReference
以附加清理事物所需的信息,然后轮询 ReferenceQueue
以获取清理任务。
ReferenceQueue<Foo> fooQueue = new ReferenceQueue<Foo>();
class ReferenceWithCleanup extends WeakReference<Foo> {
Bar bar;
ReferenceWithCleanup(Foo foo, Bar bar) {
super(foo, fooQueue);
this.bar = bar;
}
public void cleanUp() {
bar.cleanUp();
}
}
public Thread cleanupThread = new Thread() {
public void run() {
while(true) {
ReferenceWithCleanup ref = (ReferenceWithCleanup)fooQueue.remove();
ref.cleanUp();
}
}
}
public void doStuff() {
cleanupThread.start();
Foo foo = new Foo();
Bar bar = new Bar();
ReferenceWithCleanup ref = new ReferenceWithCleanup(foo, bar);
... // From now on, once you release all non-weak references to foo,
// then at some indeterminate point in the future, bar.cleanUp() will
// be run. You can force it by calling ref.enqueue().
}
例如,选择weakKeys
时Guava的CacheBuilder
实现的内部uses这种方法。
关于java - 使用 Java 的 ReferenceQueue,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14450538/
我在查看 WeakHashMap 的源代码时偶然发现了这个: private final ReferenceQueue queue = new ReferenceQueue<>(); private
一个 WeakHashMap与 WeakReference 的工作原理差不多再加上一个 ReferenceQueue - 关于这个的消息为零。这是它应该如何工作的精简示例: public class
编辑 到目前为止,大多数答案都集中在我错误地扩展 map 这一事实上。我已在示例代码中更正了此问题,但类型问题仍然存在,问题仍然存在。 我试图在 Scala 中实现 SoftHashMap,但遇到了类
我知道对于 ReferencesQueue 中的 PhantomReference,必须自己处理并清空 ReferenceQueue。 对于 ReferenceQueue 中的 WeakReferen
我想在其他线程不再引用时正确关闭 Closeable 对象。 我写了一些小测试,但是在对象入队后,get 方法返回 null,即 poll 方法返回正确的没有引用对象的对象。 public sta
这是我的代码 public class FinalizableObject { @Override protected void finalize() throws Throwable
我有一个 PR,一个 PR 指向的对象 O,以及一个为 PR 设置的 RQ。我有一个不断轮询 RQ 的线程,当它在 RQ 中找到第一个引用时,该线程打印它找到它的时间,然后退出。 一切正常,但是当 O
SoftReference 和 WeakReference 真的只有在创建为实例变量时才有帮助吗?在方法范围内使用它们有什么好处吗? 另一大部分是ReferenceQueue。除了能够跟踪哪些引用被确
我想了解垃圾收集器在什么情况下会通知您清除软引用。文档清楚地表明它在可能发生 OOM 时发生,但是如果您完全丢弃引用,GC 会出现并收集 SoftReference 可能会注意到不存在其他强/软引用并
我有一个引用队列,声明为: ReferenceQueue rqueue = new ReferenceQueue<>(); 我有一些软引用以的形式构造 SoftReference ref=new So
我有一个类 ReferenceQueue的 WeakReference class Example { ReferenceQueue> queue = null; Thread cle
这个问题在这里已经有了答案: Does JVM/GC call `finalize()` on program/thread exit? (2 个答案) 关闭 9 年前。 我知道you can't
我正在使用 LWJGL 库,不幸的是,每当我的场景图中的节点需要死亡时,我需要自己释放纹理/vbo 缓冲区,我什至无法使用 finalize() 方法来做到这一点'不保证它将在 opengl 库期望的
我的应用程序并不总是崩溃,只是在我使用它一段时间后,它就会崩溃。 我找到了其他人的解决方案,但他们对我没有帮助。 这是我的墓碑痕迹: signal 11 (SIGSEGV), code 1 (SEGV
我是一名优秀的程序员,十分优秀!