问题是:我似乎无法可靠地清除软引用。
这不是SoftReferences所独有的。由于Java中垃圾回收的性质,无法保证任何时候都可以实际收集任何可垃圾回收的东西。即使使用简单的代码:
Object temp = new Object();temp = null;System.gc();
不能保证在第一行实例化的对象在此时或实际上在任何时候都是垃圾回收。这只是您必须使用内存管理的语言来处理的事情之一,您正在放弃对这些事情的声明性权力。是的,这可能使得有时很难进行明确的内存泄漏测试。
就是说,根据您引用的Javadocs,在抛出OutOfMemoryError之前,绝对应该清除SoftReferences(实际上,这是它们的全部要点,并且是它们与默认对象引用不同的唯一方式)。因此,听起来好像存在某种内存泄漏,因为您要保留对所涉及对象的更严格的引用。
如果
-XX:+HeapDumpOnOutOfMemoryError对JVM
使用该选项,然后将堆转储加载到诸如jhat之类的东西中,则应该能够看到对对象的所有引用,从而可以查看软引用旁边是否有任何引用。或者,您可以在运行测试时使用探查器来实现相同的目的。



