使用java遍歷Map集合的方式


在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);
        }
    }

測試結果如下:

 

擴充

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2024 CODEPRJ.COM