HashMap源码学习(二)
2020-05-11 04:08
351 查看
HashMap源码学习(二)
HashMap get源码分析
public V get(Object key) { Node<K,V> e; return (e = getNode(hash(key), key)) == null ? null : e.value; } /** * Implements Map.get and related methods * * @param hash hash for key * @param key the key * @return the node, or null if none */ final Node<K,V> getNode(int hash, Object key) { //传入hash值,已经确定数据在数组中的位置 //下面只需要判断是不是第一个数据, //不是就判断数据类型 //是树按照数的方法得到 //是链表就按照链表的凡是得到。 Node<K,V>[] tab;//定义接收数组 tab Node<K,V> first, e;//定于first键值对, int n; //定义接收的数组长度 K k; if ((tab = table) != null && (n = tab.length) > 0 && (first = tab[(n - 1) & hash]) != null) { //table赋值给tab (table是要获取的hashmap) 判断数组不为空,长度大于零 //第一个数组元素不为空。 if (first.hash == hash && // always check first node ((k = first.key) == key || (key != null && key.equals(k)))) //这里判断是不是第一个元素, return first; if ((e = first.next) != null) { //判断first后没有没有元素,没有就只是元素。否则后面有元素。 if (first instanceof TreeNode) //判断first是不是树结构 return ((TreeNode<K,V>)first).getTreeNode(hash, key); //通过.getTreeNode(hash, key)查询到数结构里的数据 do { //不是数组结构和数结构,就是链表结构,对链表结构遍历,查询hash值和key值相同的找到返回e if (e.hash == hash && ((k = e.key) == key || (key != null && key.equals(k)))) return e; } while ((e = e.next) != null); } } return null; }qintaipeng 原创文章 8获赞 0访问量 198 关注 私信
相关文章推荐
- JDK源码学习(5)-Map的性能比较,HashMap和TreeMap,ConcurrentSkipListMap
- HashMap 源码学习
- java源码学习之HashMap(一)
- 学习JDK1.8集合源码之--HashMap
- JAVA源码学习-HashMap
- HashMap源码学习
- 哈希算法-----JAVA 源码中实现的HashMap学习总结
- JDK源码学习(6)-ConcurrentHashMap代码学习
- HashMap源码学习(三)
- JDK源码学习笔记——HashMap
- HashMap源码学习
- 【jdk源码学习】HashMap
- java util包学习(9)HashMap源码分析
- JDK源码学习-HashMap\Hashtable
- Java集合ArrayList和HashMap源码学习
- 第014讲:Scala中Map和HashMap源码剖析及代码实践(从1000个代码案例中学习人工智能和大数据实战)
- java中HashMap源码学习分享
- Java集合源码学习(20)_Map接口的实现HashMap
- HashMap源码学习
- 【Java集合学习系列】HashMap实现原理及源码分析