【Java面试】为什么ConcurrentHashMap中key不允许为null?看高手如何搞定面试官

“为什么ConcurrentHashMap中key不允许为null”!

听到这个问题,大家有没有感受到面试过程中的压迫感

Hi,大家好,我是Mic,一个工作了14年的Java程序员

这个问题,面试官的考察目的是什么呢?

考察目标

这是一个基础问题,主要考察1到3年经验的开发人员

ConcurrentHashMap在实际应用中使用频率较高

考察这个问题的目的,是了解求职者的基本功。

所以为了表现更好,可以从ConcurrentHashMap的设计角度去回答。

问题解析

打开ConcurrentHashMap的源码在put方法里面,可以看到这样一段代码如果key或者value为空,则抛出空指针异常。

但是为什么ConcurrentHashMap不允许key或者value为空呢?

简单来说,就是为了避免在多线程环境下出现歧义问题。

所谓歧义问题,就是如果key或者value为null,当我们通过get(key)获取对应的value的时候,如果返回的结果是null我们没办法判断,它是put(k,v)的时候,value本身为null值,还是这个key本身就不存在。

比如在这样一种情况下,线程t1调用containsKey方法判断key是否存在,假设当前这个key不存在,本来应该返回false。

但是在T1线程返回之前,正好有一个T2线程插入了这个key,但是value为null。

这就导致原本T1线程返回的结果有可能是true,有可能是false,取决于T1和T2线程的执行顺序。

这种现象我们可以认为是线程安全性问题,而ConcurrentHashMap又是一个线程安全的集合,

所以自然就不允许key或者value为null。

而HashMap中是允许存null的,因为它不需要考虑到线程安全性问题。

所以这个问题的核心本质还是ConcurrentHashMap这个并发安全性集合的特性。

当然。Doug Lea还认为,不管是否是安全的集合,它都不应该允许存储null。

高手:

ConcurrentHashMap这么设计的原因是为了避免在多线程并发场景下的歧义问题。

也就是说,当一个线程从ConcurrentHashMap获取某个key,如果返回的结果是null的时候。

这个线程无法确认,这个null表示的是确实不存在这个key,还是说存在key,但是value为空。

这种不确定性会造成线程安全性问题,而ConcurrentHashMap本身又是一个线程安全的集合。

所以才这么设计!

总结

下次面试的时候遇到这个问题,大家知道怎么回答了吗?

如果你喜欢我的作品,记得点赞收藏加关注哦!!!

另外,我将所有Java面试系列制作成了完整的面试文档。它的便捷之处在于,可以通过检索的方式,找到你想要的面试题,目前已经更新200期,总计超过20W字!

【想领取面试文档的小伙伴可以点击文章底部名片无套路免费赠送给大家!】

需要高手面试文档面试文档的小伙伴可以扫描下方二维码
↓↓↓↓↓↓↓↓↓↓↓↓↓

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

跟着Mic学架构

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值