| |
java比c++方便的一点就是java有自己的垃圾收集机制。可以自动帮你收集垃圾。但是,这并非意味着使用java我们就不需要考虑内存管理了。 这一点相信很多java程序员都是知道的,就是当一个对象我们决定不再使用的时候,最好可以手动设置它为null。特别是这个object比较耗费资源的时候。 effective java上的例子: import java.util.*;
// can you spot the "memory leak"? public class stack { private object[] elements; private int size = 0;
public stack(int initialcapacity) { this.elements = new object[initialcapacity]; }
public void push(object e) { ensurecapacity(); elements[size++] = e; }
public object pop() { if (size==0) throw new emptystackexception(); object result = elements[--size]; elements[size] = null; // eliminate obsolete reference return result; }
/** * ensure space for at least one more element, roughly * doubling the capacity each time the array needs to grow. */ private void ensurecapacity() { if (elements.length == size) { object[] oldelements = elements; elements = new object[2 * elements.length + 1]; system.arraycopy(oldelements, 0, elements, 0, size); } }
public static void main(string[] args) { stack s = new stack(0); for (int i=0; i<args.length; i++) s.push(args[i]); for (int i=0; i<args.length; i++) system.out.println(s.pop()); } } 这是一个简单的实现堆栈数据结构的程序。 这个程序的编译和测试是没有问题的。它的问题存在哪里呢? 在这个程序里,如果这个堆栈先push然后再pop的话,那么弹出来的对象不会被释放。因为栈内部维护着对这个对象永远都不会解除的引用。 我们每次弹出一个对象,都要令element[size]=null;
总结:在拥有自动垃圾收集功能的语言里,我们要特别注意内存管理的问题,因为这个时候内存的溢出问题不会象c plus plus这些那么明显。我们要防范于未然。 另外,根据matrix的经验,inputstreamreader等文件读写类,我们要在set 他们为null的之前,close他们的连接,即调用in.close().然后再in=null;(这里in是一个inputstreamreader等)。
|
|