基本介绍
- 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());
}
}
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/78409.html