基本介绍
- Map用于保存具有映射关系的数据:Key-Value;
- Map中的key和value可以是任何引用类型的数据,会封装到HashMap$Node对象中;
- Map中的key不允许重复;
- Map中的value可以重复;
- Map的key可以为null,value也可以为null,注意key为null,只能有一个,value为null,可以多个;
- 常用String类作为Map的Key;
- key和value之间存在单向一对一关系,即通过指定的key总能找到对应的value;
体系图
常用方法
V put(K key, V value) : 添加
V remove(Object key) : 根据键删除映射关系
V get(Object key) : 根据键获取值
int size() : 获取元素的个数
boolean isEmpty() : 判断个数是否为0
void clear() : 清除
boolean containsKey(Object key) : 查找键是否存在
遍历
- containsKey: 查找键是否存在
- keySet: 获取所有键
- values: 获取所有值
- entrySet: 获取所有关系
测试代码:
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
@SuppressWarnings("all")
public class HashMapSource {
public static void main(String[] args) {
Map map = new HashMap();
map.put("name", "姓名");
map.put("sex", "性别");
map.put("age", "年龄");
// 1. 取出key 遍历
Set set = map.keySet();
System.out.println("===== 1. 增强for =====");
// 1.1 增强for
for (Object o : set) {
System.out.println(o + ":" + map.get(o));
}
System.out.println("===== 2. 迭代器 =====");
// 1.2 迭代器
Iterator iterator = set.iterator();
while (iterator.hasNext()) {
Object next = iterator.next();
System.out.println(next + ":" + map.get(next));
}
System.out.println("===== 3. EntrySet =====");
Set entrySet = map.entrySet();
for (Object o : entrySet) {
Map.Entry entry = (Map.Entry) o;
System.out.println(entry.getKey() + ":" + entry.getValue());
}
}
}