为了账号安全,请及时绑定邮箱和手机立即绑定

HashMap中hash桶的疑惑

HashMap中hash桶的疑惑

潇潇雨雨 2019-03-14 14:14:58
hash bucket,据说是一个单向链表,可不可以说是一个栈?HashMap::get() 可以获取 bucket 里面的第一个元素,那其它元素又怎么获取?HashMap::size() 是返回 bucket 的个数还是长度大于 0 的 bucket 的个数?
查看完整描述

1 回答

?
慕姐4208626

TA贡献1852条经验 获得超7个赞

  1. 是一个单向链表,不是栈,栈和链表区别很大。

  2. get 是取得和你 key 匹配的那个 value。bucket 链表里面存储的是 hash 值相同的 (key,value) 对,比如 key1 和 key2 计算得到的 hash 值相同,那么就把他们扔到一个bucket里面,当你 get(key1) 时,那么遍历对应的 bucket 链表,直到找到对应的 key1,返回 value1.

  3. size() 是所有元素的个数,而不是 bucket 的个数。

你可以去看下 HashMap 的实现,比如 JDK 里面的,就很清楚了。


查看完整回答
反对 回复 2019-04-15
  • 1 回答
  • 0 关注
  • 1568 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信