在java中所有的map都实现了Map接口,因此所有的Map(如HashMap, TreeMap, LinkedHashMap, Hashtable等)都可以用以下的方式去遍历。
方法一:在for循环中使用entries实现Map的遍历
@Test
public void test2(){
/**
* 最常见也是大多数情况下用的最多的,一般在键值对都需要使用
*/
Map<String,String> map = new HashMap<>();
map.put("姓名", "张三");
map.put("年龄", "22");
for(Map.Entry<String, String> entry : map.entrySet()){
String mapKey = entry.getKey();
String mapValue = entry.getValue();
System.out.println(mapKey+" : "+mapValue);
}
}
测试结果如下:
方法二:在for循环中遍历key或者values,一般适用于只需要map中的key或者value时使用,在性能上比使用entrySet较好
@Test
public void test2(){
Map<String,String> map = new HashMap<>();
map.put("姓名", "张三");
map.put("年龄", "22");
//key
for(String key : map.keySet()){
System.out.println(key);
}
//value
for(String value : map.values()){
System.out.println(value);
}
}
测试结果如下:
方法三:通过Iterator遍历
@Test
public void test2(){
Map<String,String> map = new HashMap<>();
map.put("姓名", "张三");
map.put("年龄", "22");
Iterator<Map.Entry<String, String>> entries = map.entrySet().iterator();
while(entries.hasNext()){
Map.Entry<String, String> entry = entries.next();
String key = entry.getKey();
String value = entry.getValue();
System.out.println(key+":"+value);
}
}
测试结果如下:
方法四:通过键找值遍历,这种方式的效率比较低,因为本身从键取值是耗时的操作
@Test
public void test2(){
Map<String,String> map = new HashMap<>();
map.put("姓名", "张三");
map.put("年龄", "22");
for(String key : map.keySet()){
String value = map.get(key);
System.out.println(key+":"+value);
}
}
测试结果如下:
(扩充)