Map集合遍歷兩種方式區別和效能
阿新 • • 發佈:2019-02-04
Map<String,String> map = new HashMap<String,String>();
map.put("01", "zhangsan");
map.put("02", "lisi");
map.put("03", "wangwu");
Collection<String> collection = map.values();//返回值是個值的Collection集合
System.out.println(collection);
列印結果:
[zhangsan, lisi, wangwu]
Set<K> keySet() //返回值是個只存放key值的Set集合(集合中無序存放的)
Set<Map.Entry<K,V>> entrySet() //返回對映所包含的對映關係的Set集合(一個關係就是一個鍵-值對),就是把(key-value)作為一個整體一對一對地存放到Set集合當中的。
一. keySet()方式。
Map<String,String> map = new HashMap<String,String>();
map.put("01", "zhangsan");
map.put("02", "lisi");
map.put("03", "wangwu");
Set<String> keySet = map.keySet();//先獲取map集合的所有鍵的Set集合
Iterator<String> it = keySet.iterator();//有了Set集合,就可以獲取其迭代器。
while(it.hasNext()){
String key = it.next();
String value = map.get(key);//有了鍵可以通過map集合的get方法獲取其對應的值。
System.out.println("key: "+key+"-->value: "+value);//獲得key和value值
}
二. entrySet()方式:
Map<String,String> map = new HashMap<String,String>();
map.put("01", "zhangsan");
map.put("02", "lisi");
map.put("03", "wangwu");
//通過entrySet()方法將map集合中的對映關係取出(這個關係就是Map.Entry型別)
Set<Map.Entry<String, String>> entrySet = map.entrySet();
//將關係集合entrySet進行迭代,存放到迭代器中
Iterator<Map.Entry<String, String>> it2 = entrySet.iterator();
while(it2.hasNext()){
Map.Entry<String, String> me = it2.next();//獲取Map.Entry關係物件me
String key2 = me.getKey();//通過關係物件獲取key
String value2 = me.getValue();//通過關係物件獲取value
System.out.println("key: "+key2+"-->value: "+value2);
}
雖然使用keyset及entryset來進行遍歷能取得相同的結果
但兩者的遍歷速度是有差別的
keySet():迭代後只能通過get()取value
entrySet():迭代後可以e.getKey(),e.getValue()取key和value。返回的是Entry介面
說明:keySet()的速度比entrySet()慢了很多,也就是keySet方式遍歷Map的效能不如entrySet效能好
map.put("01", "zhangsan");
map.put("02", "lisi");
map.put("03", "wangwu");
Collection<String> collection = map.values();//返回值是個值的Collection集合
System.out.println(collection);
列印結果:
[zhangsan, lisi, wangwu]
Set<K> keySet() //返回值是個只存放key值的Set集合(集合中無序存放的)
Set<Map.Entry<K,V>> entrySet() //返回對映所包含的對映關係的Set集合(一個關係就是一個鍵-值對),就是把(key-value)作為一個整體一對一對地存放到Set集合當中的。
一. keySet()方式。
Map<String,String> map = new HashMap<String,String>();
map.put("01", "zhangsan");
map.put("02", "lisi");
map.put("03", "wangwu");
Set<String> keySet = map.keySet();//先獲取map集合的所有鍵的Set集合
Iterator<String> it = keySet.iterator();//有了Set集合,就可以獲取其迭代器。
while(it.hasNext()){
String key = it.next();
String value = map.get(key);//有了鍵可以通過map集合的get方法獲取其對應的值。
System.out.println("key: "+key+"-->value: "+value);//獲得key和value值
}
二. entrySet()方式:
Map<String,String> map = new HashMap<String,String>();
map.put("01", "zhangsan");
map.put("02", "lisi");
map.put("03", "wangwu");
//通過entrySet()方法將map集合中的對映關係取出(這個關係就是Map.Entry型別)
Set<Map.Entry<String, String>> entrySet = map.entrySet();
//將關係集合entrySet進行迭代,存放到迭代器中
Iterator<Map.Entry<String, String>> it2 = entrySet.iterator();
while(it2.hasNext()){
Map.Entry<String, String> me = it2.next();//獲取Map.Entry關係物件me
String key2 = me.getKey();//通過關係物件獲取key
String value2 = me.getValue();//通過關係物件獲取value
System.out.println("key: "+key2+"-->value: "+value2);
}
雖然使用keyset及entryset來進行遍歷能取得相同的結果
但兩者的遍歷速度是有差別的
keySet():迭代後只能通過get()取value
entrySet():迭代後可以e.getKey(),e.getValue()取key和value。返回的是Entry介面
說明:keySet()的速度比entrySet()慢了很多,也就是keySet方式遍歷Map的效能不如entrySet效能好