JAVA中的HASHSET和HASHMap的底层实现是怎样的?大致讲一下。
3个回答
展开全部
HASHSET:底层是将你加入其中的对象进行HASH排列后在放的时候,对比你放入的对象在其中是否有相同的对象存在,如果存在就不放入,反之放入。
HASHMAP:底层是将你加入其中的对象进行HASH排列后在放的时候,将key和对应的value发在一起,可以随时用key找到value,所以其中如果你让如相同的key但value不同时,后者value会替换前者。
所以,如果你不希望存相同的值是,用HASHSET,你希望能很方便的用key找到value时,用HASHMAP.
HASHMAP:底层是将你加入其中的对象进行HASH排列后在放的时候,将key和对应的value发在一起,可以随时用key找到value,所以其中如果你让如相同的key但value不同时,后者value会替换前者。
所以,如果你不希望存相同的值是,用HASHSET,你希望能很方便的用key找到value时,用HASHMAP.
更多追问追答
追问
hash后会有重复的吧?
追答
同一个值,HASH的值就是一样的
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
上面的仁兄讲的挺清楚的,
回楼主的追问,hash值是不会一样的
回楼主的追问,hash值是不会一样的
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询