HashMap存储详解

1.存储概念讲解java

        面试的时候通常会问HashMap里的数据是怎么存储的?怎么存储的和存储结构是不同的,若是回答用Entry数组来存储的是有问题。首先你应该向面试官问,是Java 7 仍是Java 8 ,由于这二者是不同的,一个是Entry数组实现的,一个是用二叉树Node来实现的。面试

2.HashMap的实现原理算法

    简单地说,HashMap就是将key作hash算法,而后将hash值映射到内存地址,直接取得key所对应的数据。在Java 7 中,底层数据结构使用的是数组,所谓的内存地址即数组的下标索引。数组

    Java 7 源码:代码中 h ^= k.hashCode();来获取Object的hashcode值。数据结构

final int hash(Object k) {
        int h = 0;
        if (useAltHashing) {
            if (k instanceof String) {
                return sun.misc.Hashing.stringHash32((String) k);
            }
            h = hashSeed;
        }

        h ^= k.hashCode();

        // This function ensures that hashCodes that differ only by
        // constant multiples at each bit position have a bounded
        // number of collisions (approximately 8 at default load factor).
        h ^= (h >>> 20) ^ (h >>> 12);
        return h ^ (h >>> 7) ^ (h >>> 4);
    }

好比:经过HashMap保存值app

public V put(K key, V value) {
        if (key == null)
            return putForNullKey(value);
        int hash = hash(key);
        int i = indexFor(hash, table.length);
        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))) {
                V oldValue = e.value;
                e.value = value;
                e.recordAccess(this);
                return oldValue;
            }
        }

        modCount++;
        addEntry(hash, key, value, i);
        return null;
    }

     经过调用hash函数int hash = hash(key);  获取hashcode,而后经过addEntry(hash, key, value, i);方法保存到Entry数组中。函数

    补充:Java8的源码。this

    获取hashcode:spa

static final int hash(Object key) {
        int h;
        return (key == null) ? 0 : (h = key.hashCode()) ^ (h >>> 16);
    }

3.hash冲突问题code

    那就要深刻HashMap的内部,它的内部维护着一个Entry数组,每个Entry表项包括key、value、next和hash几项。这里要注意的是next部分,它指向了另一个Entry。进一步阅读HashMap的put()方法,能够看到当put操做有冲突时,新的Entry依然会被安放在对应的索引下标内,并替换原有的值。同时,为了保证旧值不丢失,会将新的Entry的next指向旧值。这便实现了一个数组索引空间内存放多个值项。

相关文章
相关标签/搜索