1. 程式人生 > >map集合的keySet和entrySet

map集合的keySet和entrySet

demo 內存空間 關系 說明 class 區別 pub 1.2 包含

Set<Map.Entry<K,V>> entrySet() 返回此映射中包含的映射關系的 set 視圖。

Set<K> keySet() 返回此映射中包含的鍵的 set 視圖。

舉例說明

import java.util.*;
import java.util.Map.Entry;  
public class Demo {  

    public static void main(String[] args) {  
        Map<Integer,String> map = new HashMap<Integer,String>();
        map.put(1, "一");
        map.put(2, "二");
        map.put(3, "三");
        map.put(4, "四");
        map.put(5, "五");

        /**
         * 方法1keySet
         */
        Set<Integer> keySet = map.keySet();
        Iterator<Integer> iterator = keySet.iterator();
        while (iterator.hasNext() ){
            Integer key = iterator.next();
            String value = map.get(key);
            System.out.println("1.0"+key+"------"+value);
        }
        for (Iterator<Integer> it = keySet.iterator(); it.hasNext(); ) {
            Integer key = it.next();
            String value = map.get(key);
            System.out.println("1.1"+key+"------"+value);
        }
        for (Integer key : keySet) {
            String value = map.get(key);
            System.out.println("1.2"+key+"------"+value);
        }
        /**
         * 方法2entrySet
         */
        Set<Entry<Integer, String>> entrySet = map.entrySet();
        Iterator<Entry<Integer, String>> aiterator = entrySet.iterator();
        while (aiterator.hasNext()) {
            Entry<Integer, String> entry = aiterator.next();
            Integer key = entry.getKey();
            String value = entry.getValue();
            System.out.println("2.0"+key+"------"+value);
        }
        for (Iterator<Entry<Integer, String>> it = entrySet.iterator(); it.hasNext(); ) {
            Entry<Integer, String> entry = it.next();
            Integer key = entry.getKey();
            String value = entry.getValue();
            System.out.println("2.1"+key+"------"+value);
        }
        for (Entry<Integer, String> entry : entrySet) {
            Integer key = entry.getKey();
            String value = entry.getValue();
            System.out.println("2.2"+key+"------"+value);
        }
    }  
}  

keySet和entrySet的區別
keySet()的速度比entrySet()慢了很多,因為對於keySet其實是遍歷了2次,一次是轉為iterator,一次就從hashmap中取出key所對於的value。而entryset只是遍歷了第一次,他把key和value都放到了entry中,所以就快了

for循環和while循環對比
1.for循環比for循環節約內存空間,因為叠代器在for循環中,循環結束,叠代器屬於局部變量,循環結束就消失了,while循環中叠代器對象雖然也是局部變量但是要等方法運行完畢才能在內存中消失
2.當循環次數比較多時,while循環理論上要比for循環要高效,因為for循環比for多一條匯編語句

map集合的keySet和entrySet