为了账号安全,请及时绑定邮箱和手机立即绑定

Java中的WeakHashMap与类示例

标签:
Java


在本文中,我们将WeakHashMap 通过示例从java.util包中学习  类。

我们将学到什么?

WeakHashMap 课程概述

WeakHashMap 类构造方法摘要

WeakHashMap 类构造方法

WeakHashMap 类示例

1. WeakHashMap类概述

WeakHashMap 是一个基于Hash表的Map接口实现的弱键。当其密钥不再正常使用时,将自动删除该条目中的条目。支持空值和空值。该类具有与HashMap类相似的性能特征,并具有与初始容量和负载因子相同的效率参数。与大多数集合类一样,此类不同步。可以使用以下来构造   同步  WeakHashMap WeakHashMap Collections.synchronizedMap 方法。弱引用 - 如果对象的唯一引用是弱引用,则垃圾收集器可以随时回收对象的内存。它不必等到系统内存不足。通常,它将在下次垃圾收集器运行时释放。此类是Java Collections Framework的成员。

2. WeakHashMap类构造函数

WeakHashMap() - WeakHashMap 使用默认初始容量(16)和加载因子(0.75)构造一个新的空  。

WeakHashMap(int initialCapacity) - WeakHashMap 使用给定的初始容量和默认加载因子(0.75)构造一个新的空。

 WeakHashMap(int initialCapacity, float loadFactor) - WeakHashMap 使用给定的初始容量和给定的加载因子构造一个新的空  。

WeakHashMap(Map< ?extends K,? extends V> m)  - 构造一个WeakHashMap 与指定映射具有相同映射的new 。

3. WeakHashMap类方法

 void clear() -  从此映射中删除所有映射。

boolean containsKey(Object key) - 如果此映射包含指定键的映射,则返回true。

 boolean containsValue(Object value) - 如果此映射将一个或多个键映射到指定值,则返回true。

 Set<  Map.Entry<K,V>>entrySet() -返回此映射中包含的映射的Set视图。

void forEach(BiConsumer<? super K,? super V> action)  - 对此映射中的每个条目执行给定操作,直到处理完所有条目或操作引发异常。

 V get(Object key) -  返回指定键映射到的值,如果此映射不包含键的映射,则返回null。

boolean isEmpty() - 如果此映射不包含键 - 值映射,则返回true。

 Set keySet() - 返回此映射中包含的键的Set视图。

V put(K key, V value)  -  将指定值与此映射中的指定键相关联。

 void putAll(Map<? extends K,? extends V> m) -将指定映射中的所有映射复制到此映射。

 V remove(Object key) - 如果存在,则从此弱哈希映射中删除键的映射。

 void replaceAll(BiFunction<? super K,? super V,? extends V>function)  - 将每个条目的值替换为在该条目上调用给定函数的结果,直到所有条目都已处理或函数抛出异常。

 int size() - 返回此映射中键 - 值映射的数量。

Collection values() -  返回此映射中包含的值的Collection视图。

4. WeakHashMap类示例

如我们所知,当一个条目中的条目不再被外部引用并且密钥到期时,它将被自动删除。在这个例子中,我们创建了两个键 - key1和key2 - 值为“ACTIVE”和“INACTIVE”。现在,使key1为null并运行该程序。输出应该是单个条目: WeakHashMap

导入 java。util。地图 ;

导入 java。util。地图。进入 ;

导入 java。util。WeakHashMap ;

公共 类 WeakHashMapExample {

    public  static  void  main(final  String [] args){

        final  Map < Key,Project >  map  =  new  WeakHashMap <>();

        Key  key1  =  new  Key(“ACTIVE”);

        final  key  key2  =  new  Key(“INACTIVE”);

        地图。put(key1,new  Project(100,“Customer Management System”,“Customer Management System”));

        地图。put(key2,new  Project(200,“Employee Management System”,“Employee Management System”));

        key1  =  null ;

        系统。gc();

        为(最终 条目< 键,项目>  条目:地图。的entrySet()){

            系统。出。的println(条目。信息getKey()。信息getKey()+  “”  +  条目。的getValue());

        }

    }

}

class  Key {

    私有 String  键 ;

    public  Key(final  String  key){

        super();

        这个。key  =  key ;

    }

    public  String  getKey(){

        返回 键 ;

    }

    public  void  setKey(final  String  key){

        这个。key  =  key ;

    }

}

输出:

INACTIVE    [ 项目 编号:200,项目 名称:员工 管理 系统,

           项目 说明:员工 管理 系统 ]

请注意,key1为null,其条目将被删除并进行垃圾回收。快乐的编码!

©著作权归作者所有:来自51CTO博客作者萤火的萤的原创作品,如需转载,请注明出处,否则将追究法律责任


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消