zoukankan      html  css  js  c++  java
  • ReferenceQueue的使用

    什么时候使用ReferenceQueue?

    在java的引用体系中,存在着强引用,软引用,弱引用,虚引用,这4种引用类型。关于这四种引用类型,可以查看强引用、弱引用、软引用、虚引用


    对于软引用弱引用,我们希望当一个对象被gc掉的时候通知用户线程,进行额外的处理时,就需要使用引用队列了。ReferenceQueue即这样的一个对象,当一个obj被gc掉之后,其相应的包装类,即ref对象会被放入queue中。我们可以从queue中获取到相应的对象信息,同时进行额外的处理。比如反向操作,数据清理等。

    示例:

    package reference;
    
    import java.lang.ref.ReferenceQueue;
    import java.lang.ref.WeakReference;
    import java.util.HashMap;
    import java.util.Map;
    
    /**
     * Created by haicheng.lhc on 11/05/2017.
     *
     * @author haicheng.lhc
     * @date 2017/05/11
     */
    public class RefTest {
    
        private static ReferenceQueue<byte[]> rq = new ReferenceQueue<byte[]>();
        private static int _1M = 1024*1024;
    
        public static void main(String[] args) {
            Object value = new Object();
            Map<Object, Object> map = new HashMap<>();
            Thread thread = new Thread(() -> {
                try {
                    int cnt = 0;
                    WeakReference<byte[]> k;
                    while((k = (WeakReference) rq.remove()) != null) {
                        System.out.println((cnt++) + "回收了:" + k);
                    }
                } catch(InterruptedException e) {
                    //结束循环
                }
            });
            thread.setDaemon(true);
            thread.start();
    
            for(int i = 0;i < 10000;i++) {
                byte[] bytes = new byte[_1M];
                WeakReference<byte[]> weakReference = new WeakReference<byte[]>(bytes, rq);
                map.put(weakReference, value);
            }
            System.out.println("map.size->" + map.size());
        }
    }

    输出结果是:

    ...
    9803回收了:java.lang.ref.WeakReference@702c436b
    9804回收了:java.lang.ref.WeakReference@1744a475
    9805回收了:java.lang.ref.WeakReference@213bd3d5
    map.size->10000

    结果分析

    因为map的key是WeakReference,所以在内存不足的时候,weakReference所指向的对象就会被GC,在对象被GC的同时,会把该对象的包装类即weakReference放入到ReferenceQueue里面。但是这个map的大小是10000.

    PS

    上面的reference换成SoftReference,结果一样。



    转自:https://www.jianshu.com/p/73260a46291c
  • 相关阅读:
    leetcode 子集
    leetcode 1111. 有效括号的嵌套深度
    leetcode289 生命游戏
    关于三次握手和四次挥手,发送方和接收方处于的状态的问题。
    面试题:随意取数
    2020/3/31
    01背包和完全背包
    USACO Agri-Net 3.1
    mfc小计
    static 成员小记
  • 原文地址:https://www.cnblogs.com/AnXinliang/p/9927074.html
Copyright © 2011-2022 走看看