java - HashMap中hash桶的疑惑
迷茫
迷茫 2017-04-17 11:24:42
[Java讨论组]
  1. hash bucket,据说是一个单向链表,可不可以说是一个栈?

  2. HashMap::get() 可以获取 bucket 里面的第一个元素,那其它元素又怎么获取?

  3. HashMap::size() 是返回 bucket 的个数还是长度大于 0 的 bucket 的个数?

迷茫
迷茫

业精于勤,荒于嬉;行成于思,毁于随。

全部回复(1)
PHP中文网
  1. 是一个单向链表,不是栈,栈和链表区别很大。

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

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

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

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号