【Java】IdentityHashMap 的使用场景

44 篇文章 0 订阅

前言

最近有兴趣看一下 Druid 连接池怎么做连接管理的,看到一个类 IdentityHashMap ,这里记录一下使用场景。

1. Druid 应用场景

  • 定义
protected final Map<DruidPooledConnection, Object> activeConnections 
= new IdentityHashMap<DruidPooledConnection, Object>();
  • 最外层调用
	if (url.startsWith("/activeConnectionStackTrace-") && url.endsWith(".json")) {
        Integer id = StringUtils.subStringToInteger(url, "activeConnectionStackTrace-", ".");
        // 内部从IdentityHashMap的容器中取值
        return returnJSONActiveConnectionStackTrace(id);
    }
  • 用法概括
    Druid 的特点就是做监控,每一个连接,也就是 DruidPooledConnection 都对应一个调用栈的详情。
    这些连接的调用栈信息保存到 IdentityHashMap<DruidPooledConnection, Object>
    中,对外提供查询服务。

2. IdentityHashMap 特性

观察一下 IdentityHashMap 的 key的hash值,来自于该对象的应用地址。
在这里插入图片描述
言下之意是:IdentityHashMap 的 key ,无论属性如何改变都不影响容器的寻址
Druid 就是用这个特性保留连接的堆栈记录

3. IdentityHashMap 同步化

Collections.synchronizedMap(new IdentityHashMap<Object, ObjectName>());
  • Druid 内部线程安全的用法
    在这里插入图片描述
  • 外层使用
    在这里插入图片描述
    前文一直疑惑为什么把value泛型指定为 Object,这里倒是看懂了,这个容器有很多统计类型数据。感慨一下这个泛化的map也太多地方用了吧,业务代码这么写会被吐槽吧。

4. IdentityHashMap 处理key为空值

类比一下 HashMap,可以存储 null 的 key,是把 null 映射为 0
在这里插入图片描述

而 IdentityHashMap 将 null 映射为空对象
在这里插入图片描述在这里插入图片描述

后记

如果有池化管理对象的需求(比如连接池),且考虑将对象作为某个容器的key,此时可以考虑使用 IdentityHashMap

  • 5
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值