JavaSE-Map集合体系

一、Map集合体系
1.Map集合的特点:
(1) 存储任意的 键值对 (key-value),Map中一个集合元素是一个键值对
(2) 键:无序、无下标、不允许重复(唯一)
(3) 值:无序、无下标、允许重复
2. Map 集合中的方法
(1) V put(K key,V value) : 往Map集合中添加一个键值对,如果键在Map中没有存在,则直接添加,返回值为null;如果键在Map中已经存在,则新的Value覆盖原有的value数据,被覆盖的value数据作为返回值进行返回。【开发重点】
(2) V remove(K key):根据键,删除对应的键值对,被删除的值(value)作为返回值返回。
(3) V get(K key):根据键,返回对应的值(value)。【重点】
(4) boolean containsKey(K key):判断Map集合中是否包含指定的键,包含-true;不包含-false.
(5) boolean containsValue(V value):判断Map集合中是否包含指定的值,包含-true;不包含-false.
(6) int size() : 获取Map中键值对的个数。
3. 实现类:HashMap
注意:如果自定类型的对象存储在HashMap的键上,为保证键的不允许重复,则自定义类型的对象对应的类需要覆盖hashCode方法和equals方法;但是开始通常用 String/Integer类型的数据作为键。
(1) HashMap: JDK1.2 版本,线程不安全,运行效率较高,允许null 作为 key/value。【开发重点】
(2) Hashtable : JDK1.0版本,线程安全,运行效率慢,不允许null作为key/value
(3) Properties:是 Hashtable的子类,要求 键和值都是String类型。开发时,通常用于读取配置文件。
(4) SortedMap : 是 Map子接口,可以对键完成自动排序。实现类:TreeMap
(5) LinkedHashMap:是 HashMap的子类,按照添加的顺序完成键值对的存储。
面试题目:HashMap 和 Hashtable的区别。
4.遍历:
(1) 第一种遍历方式:键遍历,通过 keySet()方法获取Map 所有的键 【开发应用重点】

Set< K > ks = map.keySet(); // 获取所有的键
 // 利用 foreach遍历 set集合
 for(K key : ks){
// 通过 map 的 get方法,获取键对应的值
 V value = map.get(key);
 // 利用 key 和 value 操作每一个键和值即可
 }

(2) 第二种遍历方式:值遍历 ,通过 values() 获取 Map中所有的值

Collection< V > vs = map.values();
 //利用 foreach 遍历 Collection集合
 for(V value:vs){
// 通过 value 操作对应的值
 }

(3) 第三种遍历方式:键值对遍历,通过 entrySet方法获取Map中所有键值对

Set< Map.Entry< K,V>> kvs = map.entrySet();
 // 通过foreach遍历 set集合 获取每一个键值对(Entry)
 for(Map.Entry< K,V> kv : kvs ){
// 利用 Entry中提供两个方法 getKey 和 getValue 获取键和值的信息
 K key = kv.getKey(); // 从键值对中获取键的信息
 V value = kv.getValue() ; // 从键值对中获取值的信息
 // 通过 key 和 value 操作键和值
 }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值