WeakHashMap适用于缓存、监听器注册和线程上下文快照等场景,其键为弱引用,GC可回收无强引用的键及对应条目;不适用于长期存储、常量键、高并发或需迭代稳定性的场景。
WeakHashMap 适合缓存类场景,尤其是对象生命周期由外部控制、不希望Map阻止对象被回收的情况。它的核心特性是“键为弱引用”,当键对象没有其他强引用时,GC 可随时回收该键及其对应条目——这和 HashMap 完全不同,也决定了它不能用于长期稳定存储。
比如在解析
XML 或 JSON 时,对重复出现的字段名做轻量级字符串 intern 替代;或在图形渲染中缓存某次绘制用到的临时样式对象。这些对象本身可能被频繁创建又丢弃,WeakHashMap 能自动清理无效映射,避免内存泄漏。
典型如 Swing/AWT 中注册事件监听器,或自定义观察者模式。若用 HashMap 存 listener → component 映射,容易导致 component 无法被回收(listener 持有 component 引用,map 又持有 listener)。WeakHashMap 把 component 作为键,listener 作为值,就能让 component 被回收后,整条映射自动失效。
有时需要跨方法传递轻量上下文(如 traceId、用户权限快照),但又不想污染调用栈或引入强引用链。可用 WeakHashMap
WeakHashMap 不是 HashMap 的“更轻量替代品”。以下情况请直接用 HashMap、ConcurrentHashMap 或 Caffeine: