使用Map
我们知道,List是一种顺序列表,如果有一个存储学生Student实例的List,要在List中根据name查找某个指定的Student的分数,最简单的方法是遍历List并判断name是否相等,然后返回指定元素
Student target = null;
for (Student s : list) {
if ("Xiao Ming".equals(s.name)) {
target = s;
break;
}
}
System.out.println(target.score);
使用List来实现存在效率非常低的问题,因为平均需要扫描一半的元素才能确定,但我们经常会有这样的需求,这个时候就可以用到Map了,Map这种键值(key-value)映射表的数据结构,作用就是能高效通过key快速查找元素。
import java.util.HashMap;
import java.util.Map;
public class Main {
public static void main(String[] args) {
Student s = new Student("Xiao Ming", 99);
Map<String, Student> map = new HashMap<>();
map.put("Xiao Ming", s); // 将"Xiao Ming"和Student实例映射并关联
Student target = map.get("Xiao Ming"); // 通过key查找并返回映射的Student实例
System.out.println(target == s); // true,同一个实例
System.out.println(target.score); // 99
Student another = map.get("Bob"); // 通过另一个key查找
System.out.println(another); // 未找到返回null
}
}
class Student {
public String name;
public int score;
public Student(String name, int score) {
this.name = name;
this.score = score;
}
}
Map<K, V>
是一种键-值映射表,当我们调用put(K key, V value)
方法时,就把key和value做了映射并放入Map。当我们调用V get(K key)
时,就可以通过key获取到对应的value。如果key不存在,则返回null。和List类似,Map也是一个接口,最常用的实现类是HashMap
。
如果只是想查询某个key是否存在,可以调用boolean containsKey(K key)
方法.
重复放入key-value并不会有任何问题,但是一个key只能关联一个value。
Map中不存在重复的key,因为放入相同的key,只会把原有的key-value
对应的value给替换掉。
虽然key不能重复,但value是可以重复的。
遍历Map
遍历key
使用for each
循环遍历Map实例的keySet()
方法返回的Set集合,它包含不重复的key的集合
import java.util.HashMap;
import java.util.Map;
public class Main {
public static void main(String[] args) {
Map<String, Integer> map = new HashMap<>();
map.put("apple", 123);
map.put("pear", 456);
map.put("banana", 789);
for (String key : map.keySet()) {//keyset返回的是set的集合
Integer value = map.get(key);//由键值得到其value
System.out.println(key + " = " + value);
}
}
}
同时遍历key和value可以使用for each
循环遍历Map对象的entrySet()
集合,它包含每一个key-value
映射
import java.util.HashMap;
import java.util.Map;
public class Main {
public static void main(String[] args) {
Map<String, Integer> map = new HashMap<>();
map.put("apple", 123);
map.put("pear", 456);
map.put("banana", 789);
//和之前的keyset方法很不同
for (Map.Entry<String, Integer> entry : map.entrySet()) {
String key = entry.getKey();
Integer value = entry.getValue();
System.out.println(key + " = " + value);
}
}
}
Map
和List
不同的是,Map
存储的是key-value
的映射关系,并且,它不保证顺序。在遍历的时候,遍历的顺序既不一定是put()
时放入的key
的顺序,也不一定是key
的排序顺序。使用Map
时,任何依赖顺序的逻辑都是不可靠的。以HashMap
为例,假设我们放入"A"
,"B"
,"C"
这3个key
,遍历的时候,每个key
会保证被遍历一次且仅遍历一次,但顺序完全没有保证,甚至对于不同的JDK版本,相同的代码遍历的输出顺序都是不同的!所以在遍历Map时,不可假设输出的key是有序的!