AbstractMap源码解析

数据结构:键值对

public static class SimpleEntry<K,V>
        implements Entry<K,V>, java.io.Serializable
    {
        private static final long serialVersionUID = -8499721149061103585L;
        //实例域key-value
        private final K key;
        private V value;

        //构造方法
        public SimpleEntry(K key, V value) {
            this.key   = key;
            this.value = value;
        }


        public SimpleEntry(Entry<? extends K, ? extends V> entry) {
            this.key   = entry.getKey();
            this.value = entry.getValue();
        }


        public K getKey() {
            return key;
        }


        public V getValue() {
            return value;
        }


        public V setValue(V value) {
            V oldValue = this.value;
            this.value = value;
            return oldValue;
        }

        //覆写了Map中的equals方法
        public boolean equals(Object o) {
            if (!(o instanceof Map.Entry))
                return false;
            Map.Entry<?,?> e = (Map.Entry<?,?>)o;
            return eq(key, e.getKey()) && eq(value, e.getValue());
        }

        //根据Map接口推荐的hashCode方法覆写了hashCode方法
        public int hashCode() {
            return (key   == null ? 0 :   key.hashCode()) ^
                   (value == null ? 0 : value.hashCode());
        }


        public String toString() {
            return key + "=" + value;
        }

    }

方法
1、size()

//返回Map中的key-value中键值对数量
public int size() {
        return entrySet().size();
    }

2、isEmpty()

//根据Map的size判断Map是否为空
public boolean isEmpty() {
        return size() == 0;
    }

3、containsValue(Object value)

//根据给定的value,判断Map中是否存在对应的key-value存储此value
 public boolean containsValue(Object value) {
        //第一步调用entrySet方法将Map转换成一个Set集合
        //第二步调用Iterator方法对Set集合中的Entry(就是一个key-value类)进行迭代
        Iterator<Entry<K,V>> i = entrySet().iterator();
        if (value==null) {
            while (i.hasNext()) {
                Entry<K,V> e = i.next();
                if (e.getValue()==null)
                    return true;
            }
        } else {
            while (i.hasNext()) {
                Entry<K,V> e = i.next();
                if (value.equals(e.getValue()))
                    return true;
            }
        }
        return false;
    }

4、containsKey(Object key)

public boolean containsKey(Object key) {
        //第一步调用entrySet方法将Map转换成一个Set集合
        //第二步调用Iterator方法对Set集合中的Entry(就是一个key-value类)进行迭代
        Iterator<Map.Entry<K,V>> i = entrySet().iterator();

        //如果key是null,则我们用Iterator判断其中是否存在null的key,存在则返回true
        if (key==null) {
            while (i.hasNext()) {
                Entry<K,V> e = i.next();
                if (e.getKey()==null)
                    return true;
            }
        } else {
            while (i.hasNext()) {
                Entry<K,V> e = i.next();
                if (key.equals(e.getKey()))
                    return true;
            }
        }
        //如果不存在则返回false
        return false;
    }

5、get(Object key)
get(Object key)和containsKey(Object key)的内部代码原理一致,不同点在于如果Map中存在对应的key则返回对应的key-value的value

6、remove(Object key)

//根据给定key删除对应的key-value,并返回key-value的value
public V remove(Object key) {
        //第一步调用entrySet方法将Map转换成一个Set集合
        //第二步调用Iterator方法对Set集合中的Entry(就是一个key-value类)进行迭代
        Iterator<Entry<K,V>> i = entrySet().iterator();

        //用于在删除该Entry(key-value)前保存对应的Entry
        Entry<K,V> correctEntry = null;

        //如果key为空,那么就找Map是否存在key为null的
        if (key==null) {
            while (correctEntry==null && i.hasNext()) {
                Entry<K,V> e = i.next();
                if (e.getKey()==null)
                    correctEntry = e;
            }
        } else {
            while (correctEntry==null && i.hasNext()) {
                Entry<K,V> e = i.next();
                if (key.equals(e.getKey()))
                    correctEntry = e;
            }
        }
        //保存对应的value
        V oldValue = null;
        if (correctEntry !=null) {
            oldValue = correctEntry.getValue();
            ???
            i.remove();
        }
        return oldValue;
    }

keySet()

//通过在方法内部
public Set<K> keySet() {
        Set<K> ks = keySet;
        if (ks == null) {
            //一个AbstractSet内部类
            ks = new AbstractSet<K>() {
                public Iterator<K> iterator() {
                    //Iterator内部类
                    return new Iterator<K>() {
                        private Iterator<Entry<K,V>> i = entrySet().iterator();

                        public boolean hasNext() {
                            return i.hasNext();
                        }

                        public K next() {
                            return i.next().getKey();
                        }

                        public void remove() {
                            i.remove();
                        }
                    };
                }

                public int size() {
                    return AbstractMap.this.size();
                }

                public boolean isEmpty() {
                    return AbstractMap.this.isEmpty();
                }

                public void clear() {
                    AbstractMap.this.clear();
                }

                public boolean contains(Object k) {
                    return AbstractMap.this.containsKey(k);
                }
            };
            keySet = ks;
        }
        return ks;
    }

values()

//返回Map中的集合对应的values集合
public Collection<V> values() {
        Collection<V> vals = values;
        if (vals == null) {
            //在累的内部实现了一个抽象类AbstractCollection
            vals = new AbstractCollection<V>() {
                //Iterator方法内部实现了Iterator 接口
                public Iterator<V> iterator() {
                    return new Iterator<V>() {
                        private Iterator<Entry<K,V>> i = entrySet().iterator();

                        public boolean hasNext() {
                            return i.hasNext();
                        }

                        public V next() {
                            return i.next().getValue();
                        }

                        public void remove() {
                            i.remove();
                        }
                    };
                }

                public int size() {
                    return AbstractMap.this.size();
                }

                public boolean isEmpty() {
                    return AbstractMap.this.isEmpty();
                }

                public void clear() {
                    AbstractMap.this.clear();
                }

                public boolean contains(Object v) {
                    return AbstractMap.this.containsValue(v);
                }
            };
            values = vals;
        }
        return vals;
    }

equals()方法

//比较两个AbstractMap是否相等
public boolean equals(Object o) {
        //首相判断两个对象是否引用同一个地址,如果是则返回true
        if (o == this)
            return true;

        //如果地址不相等,那我们就需要判断两个对象的类型是否相同,如果不同返回false,
        //如果相同则首先将要比较的对象转换成Map类型
        if (!(o instanceof Map))
            return false;
        Map<?,?> m = (Map<?,?>) o;
        if (m.size() != size())
            return false;

        //首相返回本AbstractMap的entrySet,然后依次迭代一个key判断对应的 m 这个AbstractMap中是否存在对应的key,
        //如果存在则接着判断对应的key-value的value是否相同
        try {
            Iterator<Entry<K,V>> i = entrySet().iterator();
            while (i.hasNext()) {
                Entry<K,V> e = i.next();
                K key = e.getKey();
                V value = e.getValue();
                if (value == null) {
                    if (!(m.get(key)==null && m.containsKey(key)))
                        return false;
                } else {
                    if (!value.equals(m.get(key)))
                        return false;
                }
            }
        } catch (ClassCastException unused) {
            return false;
        } catch (NullPointerException unused) {
            return false;
        }

        return true;
    }

hashCode()

public int hashCode() {
        int h = 0;
        Iterator<Entry<K,V>> i = entrySet().iterator();
        while (i.hasNext())
            h += i.next().hashCode();
        return h;
    }

抽象方法

 public abstract Set<Entry<K,V>> entrySet();

猜你喜欢

转载自blog.csdn.net/makeliwei1/article/details/80251762
今日推荐