码迷,mamicode.com
首页 > 其他好文 > 详细

哈希表

时间:2019-06-19 20:30:21      阅读:117      评论:0      收藏:0      [点我收藏+]

标签:turn   ||   hash算法   hash   ble   nbsp   遍历   初始   amp   

 

  • 1.哈希表是如何put一个数据的?
public V put(K key, V value) {  
    // 如果table引用指向成员变量EMPTY_TABLE,那么初始化HashMap(设置容量、临界值,新的Entry数组引用)
    if (table == EMPTY_TABLE) {
        inflateTable(threshold);
    }
    // 若“key为null”,则将该键值对添加到table[0]处,遍历该链表,如果有key为null,则将value替换。没有就创建新Entry对象放在链表表头
    // 所以table[0]的位置上,永远最多存储1个Entry对象,形成不了链表。key为null的Entry存在这里 
    if (key == null)  
        return putForNullKey(value);  
    // 若“key不为null”,则计算该key的哈希值
    int hash = hash(key);  
    // 搜索指定hash值在对应table中的索引
    int i = indexFor(hash, table.length);  
    // 循环遍历table数组上的Entry对象,判断该位置上key是否已存在
    for (Entry<K,V> e = table[i]; e != null; e = e.next) {  
        Object k;  
        // 哈希值相同并且对象相同
        if (e.hash == hash && ((k = e.key) == key || key.equals(k))) {  
            // 如果这个key对应的键值对已经存在,就用新的value代替老的value,然后退出!
            V oldValue = e.value;  
            e.value = value;  
            e.recordAccess(this);  
            return oldValue;  
        }  
    }  
    // 修改次数+1
    modCount++;
    // table数组中没有key对应的键值对,就将key-value添加到table[i]处 
    addEntry(hash, key, value, i);  
    return null;  
}

  

  • 2.JDK 1.7  hash算法  和 JDK 1.8的哈希算法源码

  key.hashcode ^ h >>> 16

 

技术图片

高16位和低16位做异或操作增加随机性,减少哈希冲突

  • 3.indexFor 算法源码

  h & (length -1)

  • 4.哈希冲突是什么,如何解决哈希冲突。

哈希表

标签:turn   ||   hash算法   hash   ble   nbsp   遍历   初始   amp   

原文地址:https://www.cnblogs.com/vincestarry/p/11053890.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!