全部博文(413)
分类: Java
2010-05-18 15:29:40
Other reference:
如果你想写 一个 Java 程序,观察某对象什么时候会被垃圾收集的执行绪清除,你必须要用一个 reference 记住此对象,以便随时观察,但是却因此造成此对象的 reference 数目一直无法为零, 使得对象无法被清除。
java.lang.ref.WeakReference
不
过,现在有了 Weak Reference 之后,这就可以迎刃而解了。如果你希望能随时取得某
对象的信息,但又不想影响此对象的垃圾收集,那么你应该用 Weak Reference 来记住
此对象,而不是用一般的 reference。
A obj = new A();
WeakReference wr = new WeakReference(obj);
obj = null;
//等待一段时间,obj对象就会被垃圾回收
...
if (wr.get()==null) {
System.out.println("obj 已经被清除了 ");
} else {
System.out.println("obj 尚未被清除,其信息是 "+obj.toString());
}
...
在此例中,透过 get() 可以取得此 Reference 的所
指到的对象,如果传出值为 null 的话,代表此对象已经被清除。
这类的技巧,在设计 Optimizer 或 Debugger 这类的程序时常会用到,因为这类程序需要取得某对象的信息,但是不可以
影响此对象的垃圾收集。
java.lang.ref.SoftReference
Soft Reference 虽然和 Weak Reference 很类似,但是用途却不同。 被 Soft Reference 指到的对象,即使没有任何 Direct Reference,
也不会被清除。一直要到 JVM 内存不足时且 没有 Direct Reference 时才会清除,SoftReference 是用来设计 object-cache 之用的。如
此一来 SoftReference 不但可以把对象 cache 起来,也不会造成内存
不足的错误 (OutOfMemoryError)。我觉得 Soft Reference 也适合拿来实作 pooling 的技巧。
A obj = new A();
SoftRefenrence sr = new SoftReference(obj);
引用时
if(sr!=null){
obj = sr.get();
}else{
obj = new A();
sr = new SoftReference(obj);
}
===========================
实例:(from: http://hi.baidu.com/mynetbeans/blog/item/d72208fa8d63ac1ba9d31160.html)
Java对引用的分类
级别 |
什么时候被垃圾回收 |
用途 |
生存时间 |
强 |
从来不会 |
对象的一般状态 |
JVM停止运行时终止 |
软 |
在内存不足时 |
对象简单?缓存 |
内存不足时终止 |
弱 |
在垃圾回收时 |
对象缓存 |
gc运行后终止 |
假象 |
Unknown |
Unknown |
Unknown |
1、强引用:
public static void main(String[] args) {
MyDate date = new MyDate();
System.gc();
}
解释:即使显式调用了垃圾回收,但是用于date是强引用,date没有被回收
2、软引用:
public static void main(String[] args) {
SoftReference ref = new SoftReference(new MyDate());
drainMemory(); // 让软引用工作
}
解释:在JVM垃圾回收运行时,若内存不足,软引用被终止,等同于:
MyDate date = new MyDate();
//-------------------由JVM决定运行-----------------
If(JVM.内存不足()) {
date = null;
System.gc();
}
//-------------------------------------------------------------
3、弱引用(WeakReference):
public static void main(String[] args) {
WeakReference ref = new WeakReference(new MyDate());
System.gc(); // 让弱引用工作
}
解释:在JVM垃圾回收运行时,不管内存是否不够,弱引用都会被终止,等同于:
MyDate date = new MyDate();
//------------------垃圾回收运行------------------
public void WeakSystem.gc() {
date = null;
System.gc();
}
4、假象引用(虚引用:PhantomReferenct):
虚引用随时都有可以被GC回收,当试图通过需引用的get()方法取得强应用时,总是返回null。并且,虚引用总是和引用队列一起使用,它的作用在于跟踪垃圾回收
public static void main(String[] args) {
ReferenceQueue queue = new ReferenceQueue();
PhantomReference ref = new PhantomReference(new MyDate(), queue);
System.gc(); // 让假象引用工作,此时MyDate.finallize()就会被调用
}
解释:假象引用,在实例化后,就被终止了,等同于:
MyDate date = new MyDate();
date = null;
//-------终止点,在实例化后,不是在gc时,也不是在内存不足时--------