java -- WeakHashMap
特点
- WeakHashMap 继承于AbstractMap,实现了Map、Cloneable、java.io.Serializable接口。
- WeakHashMap 也是一个散列表,它存储的内容也是键值对(key-value)映射。
- WeakHashMap 键和值都可以是null。
- WeakHashMap 的键是“弱键”。在 WeakHashMap 中,当某个键不再正常使用时,会被从WeakHashMap中被自动移除。更精确地说,对于一个给定的键,其映射的存在并不阻止垃圾回收器对该键的丢弃,这就使该键成为可终止的,被终止,然后被回收。某个键被终止时,它对应的键值对也就从映射中有效地移除了。
- 非线程安全
扩容
因为是与HashMap类似的散列表,所以扩容跟HashMap也是类似的。
自动删除原理
1. 新建WeakHashMap,将“键值对”添加到WeakHashMap中。
实际上,WeakHashMap是通过数组table保存Entry(键值对);每一个Entry实际上是一个单向链表,即Entry是键值对链表。
2. 当某“弱键”不再被其它对象引用,并被GC回收时。在GC回收该“弱键”时,这个“弱键”也同时会被添加到ReferenceQueue(queue)队列中。
3. 当下一次我们需要操作WeakHashMap时,会先同步table和queue。table中保存了全部的键值对,而queue中保存被GC回收的键值对;同步它们,就是删除table中被GC回收的键值对。
WeakHashMap例子
package com.alibaba.itbu.job.billing; import java.util.Map; import java.util.WeakHashMap; public class WeakHashMapTest { static Map wMap = new WeakHashMap(); public static void init(){ wMap.put("1", "ding"); wMap.put("2", "job"); } public static void testWeakHashMap(){ System.out.println("first get:"+wMap.get("1")); try { Thread.sleep(5000); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } System.out.println("next get:"+wMap.get("1")); } public static void main(String[] args) { testWeakHashMap(); } }
上面例子, 第一次执行时要初始化,然后在5s内是不会清除的,大概在10几秒时会清除
第一次执行:
first get:ding
next get:ding
过一会再执行:
first get:null
next get:null
WeakHashMap的构造函数
// 默认构造函数。 WeakHashMap() // 指定“容量大小”的构造函数 WeakHashMap(int capacity) // 指定“容量大小”和“加载因子”的构造函数 WeakHashMap(int capacity, float loadFactor) // 包含“子Map”的构造函数 WeakHashMap(Map<? extends K, ? extends V> map)
WeakHashMap的API
void clear() Object clone() boolean containsKey(Object key) boolean containsValue(Object value) Set<Entry<K, V>> entrySet() V get(Object key) boolean isEmpty() Set<K> keySet() V put(K key, V value) void putAll(Map<? extends K, ? extends V> map) V remove(Object key) int size() Collection<V> values()
WeakHashMap遍历方式
方法一,遍历键值对
// 假设map是WeakHashMap对象 // map中的key是String类型,value是Integer类型 Integer integ = null; Iterator iter = map.entrySet().iterator(); while(iter.hasNext()) { Map.Entry entry = (Map.Entry)iter.next(); // 获取key key = (String)entry.getKey(); // 获取value integ = (Integer)entry.getValue(); }
方法二,遍历键
// 假设map是WeakHashMap对象 // map中的key是String类型,value是Integer类型 String key = null; Integer integ = null; Iterator iter = map.keySet().iterator(); while (iter.hasNext()) { // 获取key key = (String)iter.next(); // 根据key,获取value integ = (Integer)map.get(key); }
方法三,遍历值
// 假设map是WeakHashMap对象 // map中的key是String类型,value是Integer类型 Integer value = null; Collection c = map.values(); Iterator iter= c.iterator(); while (iter.hasNext()) { value = (Integer)iter.next(); }
相关推荐
WeakHashMap是Java中的一种特殊的哈希表实现,它使用弱引用(Weak Reference)来保存键对象。当键对象没有被其他强引用引用时,在垃圾回收时会自动从WeakHashMap中移除对应的键值对。
WeakHashMap和IdentityHashMap则提供了特殊的键引用策略。 3. 工具类: - **Collections**: 提供了一系列静态方法,用于操作集合,如排序、查找、填充、反转等。 - **Arrays**: 用于处理数组,包含排序、比较、...
- **缓存反射对象**:使用WeakHashMap或ConcurrentHashMap存储已获取的Class、Method、Constructor对象,避免重复查找。 - **使用invokeStatic()**:如果可以,优先考虑使用Method的invokeStatic(),以减少对象...
- **WeakHashMap**:允许键被垃圾回收的映射。 - **Collections**:提供了许多静态方法来操作集合。 #### 五、输入/输出流 Java 提供了多种 I/O 操作的方式,包括文件读写、网络通信等。 - **File**:表示文件和...
Java编程WeakHashMap实例解析 WeakHashMap是Java编程中的一种特殊的HashMap实现,它使用弱引用来保存键和值,这样可以使得垃圾回收器自动清理键和值。在WeakHashMap中,键和值都是弱引用的,这样可以避免内存泄露...
【描述】"Java-WeakIdentityHashMap.zip, weakhashmap identityhashmapa独立库的组合,用于weakidentityhashmap实现内/外字段" 描述的是一个特定的Java数据结构实现,即WeakIdentityHashMap。这是一个结合了...
Java提供了HashMap、TreeMap和WeakHashMap等实现。 9. **堆**:堆是一种特殊的树形数据结构,满足最大堆或最小堆的性质。Java的PriorityQueue实现了堆的概念。 10. **树**:树包括二叉树、平衡树(如AVL树和红黑树...
Java 类集框架是Java编程语言中用于存储和操作对象集合的核心组件。它提供了一系列接口和类,方便开发者处理各种数据结构,如列表、队列、集合、映射等。类集框架的最大父接口是`Collection`,而`Map`接口则是处理...
### Java常见面试题详解 #### 1. Java访问修饰符:`public`,... - `WeakHashMap`: 允许键被垃圾回收器回收的 `Map` 实现。 这些集合类和接口共同构成了 Java 中处理复杂数据结构的基础,为开发者提供了强大的工具集。
例如,我们可以创建一个基于弱引用的WeakHashMap,当Key不再被引用时,Key-Value对将自动从Map中移除,这在内存管理中非常有用。 标签“系统开源”表明,我们可以通过阅读和学习开源的Collections源码,了解其设计...
WeakHashMap是Java中的一种哈希映射表,它的键是弱引用的,意味着当 WeakHashMap 的键对象只有 WeakHashMap 自己持有时,垃圾回收器可以将其回收。WeakHashMap 的使用方法主要体现在以下几个方面: 1. WeakHashMap...
Java 提供了丰富的集合类,如ArrayList、Vector、LinkedList、Stack、HashSet、TreeSet、LinkedHashSet、PriorityQueue、HashMap、TreeMap、LinkedHashMap、Hashtable、IdentityHashMap、WeakHashMap等。Collections...
本仓库记录了我的Java学习进阶之路,涵盖了Java基础、JDK源码、JVM中的重要知识,附有代码和博客讲解,旨在提供一个Java在线共享学习平台,帮助更多的...Java集合框架源码解读(4)——WeakHashMap Java集合框架源码解读
Java 1.6后提供了`WeakHashMap`,可以用于存储弱引用的观察者。 - **多参数通知**:默认的`update`方法只传递了一个`Object`参数,可能无法满足复杂场景的需求。可以通过自定义参数类型或使用`java.util.EventObject...
《Java 基础核心总结》 Java 概述 什么是 Java2 Java 的特点Java 开发环境 JDK JRE Java 开发环境配置 Java 基本语法 数据类型基础语法运算符 Java 执行控制流程条件语句 if 条件语句 if...else 条件语句if...else ...
- 使用缓存,如使用WeakHashMap存储已经反射得到的Field、Method或Constructor对象,避免重复查找。 - 避免反射调用敏感方法,如修改final字段或私有成员,除非明确知道这样做是安全的。 总之,Java反射机制为...
WeakHashMap和IdentityHashMap则提供了特殊的键值映射策略。 此外,Java的I/O流系统支持字符和字节流,如File类处理文件操作,InputStream和OutputStream处理字节流,Reader和Writer处理字符流。null是Java中的特殊...
7. **缓存机制**:为了提升性能,系统可能使用了内存缓存,如Java的WeakHashMap或Guava Cache,将频繁访问的数据暂存于内存中,减少对硬盘的访问。 8. **权限管理**:管理员账号的设置涉及权限控制,系统可能使用了...
在内存模型方面,Java 9引入了弱引用关联映射表(`WeakHashMap`)的新实现,这在处理内存敏感的应用场景中更有优势。 最后,Java 9对Javadoc也进行了改进,支持Markdown语法,使得文档注释更加易读和格式化。 总的来...