自我实现HashMap

为了加深对JDK HashMap的理解,决定自我实现个HashMap。虽不能做到如JDK源码那般细节复杂,但也基本摸清了HashMap的原理流程,也算是融汇贯通。

HashMap以键值对的方式存储数据,数据结构可理解为“链表的数组”。通过插入元素key值的hashcode和自带的hash算法决定元素的存储位置,发生hash冲突则在此节点下拉一个二元组链表,依次比较链表中的key是否与插入元素key相同,相同则覆盖,都不同则在链表起始点插入该新元素。

 

1 //首先是Entry类
  2 
  3 public class Entry<K,V> {
  4 
  5   final K key;//key一旦指定就不可改变
  6 
  7   V value;
  8 
  9   Entry<K,V> next;//指向下一元素的“指针”
 10 
 11   public Entry(K key, V value, Entry<K,V> next) {
 12 
 13     this.key = key;
 14 
 15     this.value = value;
 16 
 17     this.next = next;
 18 
 19   }
 20 
 21 }
 22 
 23  
 24 
 25 //这里省略了负载因子、扩容等操作,如需了解请查看JDK源码
 26 
 27 public class MyHashMap<K,V> {
 28 
 29   private static final INITIAL_CAPACITY = 16;//默认容量
 30 
 31   private int size;//
 32 
 33   private Entry<K,V>[] table;//array buffer 链表的数组
 34 
 35   public MyHashMap(int size) {
 36 
 3
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值