zoukankan      html  css  js  c++  java
  • Java系列: 关于虚引用及其测试代码

       “虚引用”顾名思义,就是形同虚设,与其他几种引用都不同,虚引用并不会决定对象的生命周期。如果一个对象仅持有虚引用,那么它就和没有任何引用一样,在任何时候都可能被垃圾回收器回收。
    虚引用主要用来跟踪对象被垃圾回收器回收的活动。虚引用与软引用和弱引用的一个区别在于:虚引用必须和引用队列 (ReferenceQueue)联合使用。当垃圾回收器准备回收一个对象时,如果发现它还有虚引用,就会在回收对象的内存之前,把这个虚引用加入到与之 关联的引用队列中。

    ReferenceQueue queue = new ReferenceQueue ();
    PhantomReference pr = new PhantomReference (object, queue); 


    程序可以通过判断引用队列中是否已经加入了虚引用,来了解被引用的对象是否将要被垃圾回收。如果程序发现某个虚引用已经被加入到引用队列,那么就可以在所引用的对象的内存被回收之前采取必要的行动。

     
    测试代码如下:
      
    public class App 
    {
        public static void main( String[] args ) throws InterruptedException
        {
            Object obj = new Object();
            ReferenceQueue queue = new ReferenceQueue ();
            PhantomReference<Object> pf = new PhantomReference<Object>(obj, queue);
            obj=null;
            
            while(true){
                System.out.printf("pf.get() = %d, isEnqueued: %b
    ", pf.get(), pf.isEnqueued());
                if(pf.isEnqueued())
                    break;
                System.gc();
                Thread.sleep(1000);                
            }
        }
    }
     
    输出结果:
    1. pf.get()= null, isEnqueued: false
    2. pf.get()= null, isEnqueued: true
     
  • 相关阅读:
    ZOJ1542 POJ1861
    Codeforces Round #194 (Div. 2) 部分题解
    SRM585 div2
    hdu 4627 The Unsolvable Problem
    hdu 4622 Reincarnation
    hdu 4617 Weapon
    hdu 4609 3-idiots
    hdu 4616 Game
    hdu 4611 Balls Rearrangement
    hdu 4618 Palindrome Sub-Array
  • 原文地址:https://www.cnblogs.com/strinkbug/p/6372343.html
Copyright © 2011-2022 走看看