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

Map初见

时间:2017-03-27 19:38:34      阅读:161      评论:0      收藏:0      [点我收藏+]

标签:定义   pre   map   技术分享   ges   src   tor   hash   tab   

 * @see HashMap
 * @see TreeMap
 * @see Hashtable
 * @see SortedMap
 * @see Collection
 * @see Set
 * @since 1.2
 */
public interface Map<K,V> {
}

Map 是一个接口, Map 里面有个Entry<K,V>类.一个Map里面不会有重复的key,一个key对应一个value。

Map接口里面定义了很多基本的方法, 如clear(),size(),value(),repalce(),get()等等。

Map主要围绕的 key,value , 以及Entry<K,V> .

技术分享

Map中还在自身接口中, 又定义了一个Entry的接口,这个是所有的Map类型都会实现的一个接口。

说实话,个人感觉, Map有点像是个list,( List<Entry<E,V>>), list里面装的是0个或者0个以上的Entry<K,V>。但是里面的方法肯定各有各的特点。

那么里面的方法是如何实现的呢, 现在取AbstractMap 这个实现了Map接口的抽象来看看里面的方法。

看看最常用的get(k)方法, 使用Iterator,遍历map里的所有entry,找到对应value,简单易懂.

注意,在AbstractMap中,有个类SimpleEntry<K,V> 实现了 Map.Entry<K,V>. 并实现了里面的方法.

所有实现Map接口的类,都会有对应自己的Entry 实现Map.Entry<K,V>.

public V get(Object key) {
        Iterator<Entry<K,V>> i = entrySet().iterator();
        if (key==null) {
            while (i.hasNext()) {
                Entry<K,V> e = i.next();
                if (e.getKey()==null)
                    return e.getValue();
            }
        } else {
            while (i.hasNext()) {
                Entry<K,V> e = i.next();
                if (key.equals(e.getKey()))
                    return e.getValue();
            }
        }
        return null;
    }

 

Map初见

标签:定义   pre   map   技术分享   ges   src   tor   hash   tab   

原文地址:http://www.cnblogs.com/YYfish/p/6628223.html

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