java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > Java的WeakHashMap和EnumMap、IdentityHashMap

Java集合中的WeakHashMap、IdentityHashMap、EnumMap详解

作者:桉树先生

这篇文章主要介绍了Java集合中的WeakHashMap、IdentityHashMap、EnumMap详解,HashMap的key保留了对实际对象的强引用,这意味着只要HashMap对象不被销毁,还HashMap的所有key所引用的对象就不会被垃圾回收,需要的朋友可以参考下

WeakHashMap

WeakHashMap与HashMap的用法基本类似。

区别:

注意:

如果需要使用WeakHashMap的key来保留对象的弱引用,则不要让该key所引用的对象具有任何强引用,否则将失去WeakHashMap的意义。

示例:

package com.map;
import java.util.WeakHashMap;
public class WeakHashMapTest {
public static void main(String[] args) {
    WeakHashMap wak = new WeakHashMap();
    //两个key都是匿名字符串对象(没有其他引用)
    wak.put(new String("数学"), new String("优良"));
    wak.put(new String("语文"), new String("良好"));
    //该key是一个系统缓存的字符串对象
    wak.put("java", new String("好"));①
    System.out.println(wak);
    //{java=良好, 数学=优良, 语文=良好}
    //通知系统进行垃圾回收
    System.gc();
    System.runFinalization();
    System.out.println(wak);//{java=好}
}
}

结果上来看:当系统进行垃圾时,删除了WeakHashMap 对象的前两个key-value对,因为添加前两个key-value对时,这两个key都是匿名的字符串对象,WeakHashMap 只保留了对它们的弱引用,这样垃圾回收时会自动删除这两个key-value对。

WeakHashMap对象中①标示处的key是一个字符串直接量(系统会自动保留对该字符串对象的强引用),所以垃圾回收时不会回收它。

IdentityHashMap

在IdentityHashMap中,当且仅当两个key严格相等(key1==key2)时,IdentityHashMap才认为两个key相等;相对于普通HashMap而言,只要key1和key2通过equals()方法返回true,且它们的hashCode值相等即可。

注意:

IdentityHashMap是一个特殊的Map实现!此类实现Map接口时,它有意违反Map的通常规范:IdentityHashMap要求两个key严格相等才认为两个key相等。IdentityHashMap不保证key-value对之间的顺序,更不能保证它们的顺序随时间的推移保持不变。

示例:

package com.map;
import java.util.IdentityHashMap;
public class IdentityHashMapTest {
    public static void main(String[] args) {
        IdentityHashMap idenmap = new IdentityHashMap();
        idenmap.put(new String("语文"), 80);
        idenmap.put(new String("语文"), 89);
        idenmap.put("java", 80);
        idenmap.put("java", 80);
        System.out.println(idenmap);
        //{语文=80, java=80, 语文=89}
    }
}

IdentityHashMap对象中添加了4个key-value对,前2个key-value对中的key是最新创建的字符串对象,它们通过==比较不相等,所以IdentityHashMap 会把他们当成2个key来处理;后2个key-value都是字符串直接量,而且它们的字符序列完全相同,Java使用常量池来管理字符串直接量,所以它们通过==比较返回true,IdentityHashMap 会认为它们是同一个key,因此只有一次可以添加成功。

EnumMap

EnumMap是一个与枚举类一起使用的Map实现,EnumMap中的所有key都必须是单个枚举类的枚举值。创建EnumMap时必须显示或隐式的指定它对应的枚举类。

EnumMap特征:

如果只是查询是否包含值为null的key,或只是删除值为null的key,都不会抛出异常。

与普通的Map有所区别的是,创建EnumMap是必须指定一个枚举类,从而将该EnumMap和指定枚举类关联起来。

示例:

package com.map;
import java.util.EnumMap;
public class EnumMapTest {
    public static void main(String[] args) {
        EnumMap map = new EnumMap(Season.class);
        map.put(Season.SPRING, "春天");
        map.put(Season.SUMMER, "夏天");
        System.out.println(map);
        //{SPRING=春天, SUMMER=夏天}
    }
}
enum Season{
    SPRING,SUMMER,FAIL,WINTER
}

到此这篇关于Java集合中的WeakHashMap、IdentityHashMap、EnumMap详解的文章就介绍到这了,更多相关Java的WeakHashMap和EnumMap、IdentityHashMap内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文