set为什么不能存储重复值

图示

set的两个主要实现类,TreeSet和HashSet,底层存储结构都是用的map,而且是将set需要存储的值放在map的key里的,PRESENT是一个空的object对象。

map每次put如果key值不存在,返回的是null,key值如果存在,则返回之前key的oldValue,这样与null做对比的时候返回的就是false,在set层面就是插入重复值失败了

posted @ 2020-04-18 08:03  那些年的代码  阅读(1922)  评论(0编辑  收藏  举报