这取决于一点,当你想到nulling引用。
如果你有一个对象链A-> B-> C,那么一旦A不可达,A,B和C都将有资格进行垃圾回收(假设没有其他指的是B或C)。例如,没有必要,并且从来没有任何需要,将参考A→B或B→C显式地设置为空。
除此之外,大多数时候这个问题并不真的出现,因为在现实中你正在处理集合中的对象。你通常应该总是通过调用适当的remove()方法来从列表,地图等中删除对象。
其中曾经存在一些建议来设置对null的引用的情况具体地在长期的范围内,其中内存密集型对象停止在范围中途使用。例如:
{
BigObject obj = ...
doSomethingWith(obj);
obj = null;
doSomethingElse();
}
这里的理由是因为obj仍在范围内,那么没有显式的引用的nulling,直到doSomethingElse()方法完成后才会被垃圾收集。这是可能不再适用于现代JVM的建议:事实证明,JIT编译器可以在什么时候不再使用给定的本地对象引用。