Java中HashSet的Value为什么存PRESENT而不是Null?
找到这个问题答案最简单的方法,就是看一下源码,也顺便了解一下HashSet其他方面的知识。
打开HashSet的源码,可以看到:
首先可以看到,HashSet的底层实现,是基于HashMap的。
private static final Object PRESENT = new Object();map = new HashMap<>();因为底层实现是HashMap,这也就理解了为什么HashSet不允许重复。
另外,很容易就发现我们需要找的内容:PRESENT
private static final Object PRESENT = new Object();先看add()方法,可以发现插入到HashMap里面的value是一个final的Object对象,而不是Null:
最后,我们在remove方法里面,可以找到我们需要的答案:
由于HashSet的Remove实质就是HashMap的Remove,所以在看下HashMap的源码:
想象一下,如果HashSet中底层的value存null的话,那么当map.remove(o)==null的时候,是没有办法知道这个null究竟代表了什么。
希望我的回答,能够帮助到你!
我会持续分享Java程序开发、架构设计、职业发展等方面的知识和见解,希望能得到你的关注今日头条【会点代码的大叔】,转载请注明出处。
Copyright © 广州京杭网络科技有限公司 2005-2025 版权所有 粤ICP备16019765号
广州京杭网络科技有限公司 版权所有