本文章转载于 赵斌Zz 的原创文章:https://blog.csdn.net/zhaobin0731/article/details/98962624
Map集合基于 键(key)/值(value)映射。每个键最多只能映射一个值。键可以是任何引用数据类型的值,不可重复;值可以是任何引用数据类型的值,可以重复;键值对存放无序。
HashMap的使用
HashMap<String,Integer> map=new HashMap<String,Integer>();
HashMap<Integer,Integer> map=new HashMap<>();
HashMap常用方法
<1> put(K key, V value) 将键(key)/值(value)映射存放到Map集合中。
日常使用时通常需要考虑:键key是否已经存在于map,用if-else判断又显得很繁琐,因此可以配合getOrDefault()方法:获取指定 key 对应对 value,如果找不到 key ,则返回设置的默认值。
HashMap<Integer,Integer> map = new HashMap<>();
int key = 9;
int value = 10;
map.put(key, map.getOrDefault(key,0) + value);
上述代码实现了:如果map中不存在key,创建键值对key-value;如果存在,将值更新为 value + 原来的值 。
<2> get(Object key) 返回指定键所映射的值,没有该key对应的值则返回 null。
HashMap<Integer,Integer> map = new HashMap<>();
map.put(12,9);
int i = map.get(12);
由于每个键对应一个值,一个值可能对应不同键,所以只提供了根据键获取值的方法。
<3> size() 返回Map集合中数据数量。
<4> clear() 清空Map集合
<5> isEmpty () 判断Map集合中是否有数据,如果没有则返回true,否则返回false
<6> remove(Object key) 删除Map集合中键为key的数据并返回其所对应value值。
<7> values() 返回Map集合中所有value组成的以Collection数据类型格式数据。
HashMap<String,Integer> map=new HashMap<String,Integer>();
map.put("zhaobin",70);
map.put("bob", 60);
map.put("bb", 6);
System.out.println(map.values());
输出结果:
[70, 6, 60]
<8> keySet() 返回Map集合中所有key组成的Set集合。
由于map中键值对的存储是无序的,因此不能按照索引的方式遍历。
HashMap<String,Integer> map=new HashMap<String,Integer>();
map.put("zhaobin",70);
map.put("bob", 60);
map.put("bb", 6);
System.out.println(map.keySet());
输出结果:
[zhaobin, bb, bob]
可以用于遍历map:
for(String key: map.keySet()){
//对键key进行操作;
}
<9> containsKey(Object key) 判断集合中是否包含指定键,包含返回 true,否则返回false
<10> containsValue(Object value) 判断集合中是否包含指定值,包含返回 true,否则返回false。
<11> entrySet() 遍历集合,将Map集合每个key-value转换为一个Entry对象并返回由所有的Entry对象组成的Set集合
Map<String, String> studentMap = new HashMap<String, String>();
studentMap.put("002", "小王");
studentMap.put("001", "小李");
for (Entry<String, String> entry : studentMap.entrySet()) {
String key = entry.getKey();
String value = entry.getValue();
System.out.println(key+":"+value);
}