- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Java集合框架之Map实例解析1、Map概述1.1 什么是MapMap是将键映射到值( key-value )的对象。一个映射不能包含重复的键;每个键最多只能映射到一个值。Map 接口提供三种collection 视图,允许以键集(keySet())、值集(values())或键-值映射关系集(entrySet())的形式查看某个映射的内容( 即获取键值对的内容 )。映射顺序定义为迭代器在映射的 collection 视图上返回其元素的顺序,即可以映射得到键、值和键-值的Set集合,元素的顺序是由得到的Set集合所决定的。某些映射实现可明确保证其顺序,如 TreeMap 类;另一些映射实现则不保证顺序,如 HashMap 类。1.2 Map与Collection的区别1.Map 存储的是键值对形式的元素,键唯一,值可以重复。2.Collection 存储的是单列元素,子接口Set元素唯一,子接口List元素可重复。3.Map集合的数据结构值针对键有效,跟值无关,Collection集合的数据结构是针对元素有效关于Collection可以戳这里java集合框架之Collection实例解析2、Map继承体系下面列出了常见Map集合的继承体系与他们的特点---Map 键唯一 |------HashMap基于哈希表的 Map 接口的实现。此实现提供所有可选的映射操作,并允许使用 null 值和 null 键。(除了非同步和允许使用 null 之外,HashMap 类与 Hashtable 大致相同。)此类不保证映射的顺序,特别是它不保证该顺序恒久不变。此实现不是同步的。 |------LinkedHashMap Map接口的哈希表和链接列表实现,具有可预知的迭代顺序。此实现与 HashMap 的不同之处在于,后者维护着一个运行于所有条目的双重链接列表。此链接列表定义了迭代顺序,该迭代顺序通常就是将键插入到映射中的顺序(插入顺序)。此实现不是同步的 |------WeakHashMap以弱键实现的基于哈希表的 Map。在 WeakHashMap 中,当某个键不再正常使用时,将自动移除其条目。更精确地说,对于一个给定的键,其映射的存在并不阻止垃圾回收器对该键的丢弃,这就使该键成为可终止的,被终止,然后被回收。丢弃某个键时,其条目从映射中有效地移除,null 值和 null 键都被支持。 |------Hashtable此类实现一个哈希表,该哈希表将键映射到相应的值。任何非 null 对象都可以用作键或值。 Hashtable 是同步的 |------TreeMap基于红黑树(Red-Black tree)的 NavigableMap 实现。该映射根据其键的自然顺序进行排序,或者根据创建映射时提供的 Comparator 进行排序,具体取决于使用的构造方法。此实现不是同步的3、Map泛型接口Map特点:由key-value键值对组成,键不可重复,值可重复大致包含如下功能:插入(put、putAll())、删除(remove())获取(entrySet()、get()、keySet()、size()、values())判断(containsKey()、containsValue()、equals()、isEmpty())、清除(clear())替换(replace(),replace(K key, V oldValue, V newValue) jdk1.8之后,后面示例会讲到它们)方法摘要 void clear() 从此映射中移除所有映射关系(可选操作)。boolean containsKey(Objectkey) 如果此映射包含指定键的映射关系,则返回true。boolean containsValue(Object value) 如果此映射将一个或多个键映射到指定值,则返回true。SetMap.EntryK,V entrySet() 返回此映射中包含的映射关系的Set视图。booleanequals(Object o) 比较指定的对象与此映射是否相等。 V get(Objectkey) 返回指定键所映射的值;如果此映射不包含该键的映射关系,则返回 null。 int hashCode() 返回此映射的哈希码值。boolean isEmpty() 如果此映射未包含键-值映射关系,则返回true。SetK keySet() 返回此映射中包含的键的Set视图。 V put(K key, V value) 将指定的值与此映射中的指定键关联(可选操作)。 void putAll(Map? extends K,? extends V m) 从指定映射中将所有映射关系复制到此映射中(可选
文档评论(0)