容器 - ConcurrentHashMap为何不支持null键和null值

ConcurrentHashMap为何不支持null键和null值

背景

最近在梳理总结《集合 - 常用Map之间区别》, 其中有一点就是 HashMap 是支持null键和null值,而 ConcurrentHashMap 是不支持的;

后来查看了一下jdk源码,证明了确实是这样的。

HashMap.java 部分源码

    static final int hash(Object key) {
        int h;
        return (key == null) ? 0 : (h = key.hashCode()) ^ (h >>> 16);
    }

ConcurrentHashMap.java 部分源码

    /** Implementation for put and putIfAbsent */
    final V putVal(K key, V value, boolean onlyIfAbsent) {
        if (key == null || value == null) throw new NullPointerException();
        int hash = spread(key.hashCode());
        int binCount = 0;
        ......
    }

知其然不知其所以然

后来,当有人问起我为什么ConcurrentHashMap不支持null key value时,我却只能说源码里就那么写的,却不知为何!

知其所以然

上网google了一下,发现一片很不错的文章关于ConcurrentHashMap为什么不能put null,正好能解释我的疑惑。

里面提到:

ConcurrentHashMap不能put null 是因为 无法分辨是key没找到的null还是有key值为null,这在多线程里面是模糊不清的,所以压根就不让put null。

里面重点提到一个大师Doug Lea,据说是ConcurrentHashMap的作者,赶紧查看了源码:

 /**
 * ...
 * Java Collections Framework</a>.
 *
 * @since 1.5
 * @author Doug Lea
 * @param <K> the type of keys maintained by this map
 * @param <V> the type of mapped values
 */
public class ConcurrentHashMap<K,V> extends AbstractMap<K,V>
    implements ConcurrentMap<K,V>, Serializable {
    private static final long serialVersionUID = 7249069246763182397L;
    ...
}

原来整个java.util.concurrent大多都是Lea大师的作品,值得细细品味。

相关资料

转载于:https://my.oschina.net/mengzhang6/blog/2961834

发布了154 篇原创文章 · 获赞 47 · 访问量 25万+
展开阅读全文
评论将由博主筛选后显示,对所有人可见 | 还能输入1000个字符

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 大白 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览