概述
- Map集合基于 键(key)/值(value)映射。每个键最多只能映射一个值。键可以是任何引用数据类型的值,不可重复;值可以是任何引用数据类型的值,可以重复;键值对存放无序。
Map常用实现类:
- HashMap:允许使用 null 值和 null 键;此类不保证映射的顺序;在多线程操作下不安全
- LinkedHashMap:基于哈希表和链接列表的实现类;具有可预知的迭代顺序(双重链接表的有序性)
- Properties:Hashtable的一个子类;属性列表中每个键及其对应值都是一个字符串;在多线程操作下安全。
Map接口常用方法
- put(K key, V value) 将键(key)/值(value)映射存放到Map集合中
- get(Object key) 返回指定键所映射的值,没有该key对应的值则返回 null
- size() 返回Map集合中数据数量
- clear() 清空Map集合
- isEmpty () 判断Map集合中是否有数据,如果没有则返回true,否则返回false
- remove(Object key) 删除Map集合中键为key的数据并返回其所对应value值。
- values() 返回Map集合中所有value组成的以Collection数据类型格式数据。
- containsKey(Object key) 判断集合中是否包含指定键,包含返回 true,否则返回false
- containsValue(Object value) 判断集合中是否包含指定值,包含返回 true,否则返回false
- keySet() 返回Map集合中所有key组成的Set集合
- entrySet() 将Map集合每个key-value转换为一个Entry对象并返回由所有的Entry对象组成的Set集合
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;
public class Test {
public static void main(String[] args) {
Map<String, Integer> map = new HashMap<>();
map.put("Tom", 100);
map.put("Lily", 120);
map.put("Jack", 320);
Set<String> set = map.keySet();
for (String key : set) {
System.out.println(map.get(key));
}
Set<Entry<String, Integer>> entry = map.entrySet();
for (Entry<String, Integer> entry2 : entry) {
System.out.println(entry2.getValue());
entry2.getKey();
}
Iterator<Entry<String, Integer>> iterator = entry.iterator();
while(iterator.hasNext()) {
Entry entry3 = iterator.next();
entry3.getValue();
entry3.getKey();
}
}
}