一:put()方法:
以put(k,v)举例:
第一步:算出元素在数组中的索引:
1.先将k,v封装到Node对象当中(节点) ,接着计算key的hash值(不是单纯的调用key的hashCode方法)(h = key.hashCode()) ^ (h >>> 16)足够散列,高低位的异或
2.hash值和(数组空间大小 - 1)做与运算,计算元素在数组中的索引。
第二步:比较并添加元素:
将hash值转换成数组的下标,下标位置上如果没有任何元素,就把Node添加到这个位置上。如果说下标对应的位置上有链表。此时,就会拿着k和链表上每个节点的k进行equal。如果所有的equals方法返回都是false,那么这个新的节点将被添加到链表的末尾。如其中有一个equals返回了true,那么这个节点的value将会被覆盖。
二:get()方法:
以get(k)举例。
1.和put一样,计算出k的哈希值,并转换成数组下标。
2.通过上一步哈希算法转换成数组的下标之后,在通过数组下标快速定位到某个位置上。如果这个位置上什么都没有,则返回null。如果这个位置上有单向链表,那么它就会拿着K和单向链表上的每一个节点的K进行equals,如果所有equals方法都返回false,则get方法返回null。如果其中一个节点的K和参数K进行equals返回true,那么此时该节点的value就是我们要找的value了,get方法最终返回这个要找的value。