第六条 消除过期引用
JAVA中依然会有 memory leak的,比如一个栈先增长再收缩,那么从栈中弹出的对象是不会被当做垃圾回收的,即时使用栈的程序不再引用这些对象。这是因为栈的内部维护着对这些对象的过期引用(永远也不会被解除的引用),需要显示的将这些对象清空(置为null),告诉垃圾回收器回收这些对象。
比如Stack类的实现里,pop()函数最后会有对element置null的操作:
public synchronized E pop() { E obj; int len = size(); obj = peek(); removeElementAt(len - 1); return obj; } public synchronized void removeElementAt(int index) { ........... ........... elementData[elementCount] = null; /* to let gc do its work */ }
除了栈上的内存泄露以外,还有缓存上的内存泄露,即把对象放缓存然后忘记;还有监听器和其他回调时,这个貌似不太严重。。。。
第七条 避免使用终结方法(finalizer)
总得来说finalizer是不可预测的,也是危险的,一般情况下不必要使用。
它不能保证及时的被执行(finalizer线程优先级很低,可能等待处理的队列越来越多,但是它又不能执行处理动作),甚至不被执行,导致内存泄露。
同时它本身的性能也不好
直接使用显示终止方法,比如try finally即可