Java HashMap 遍歷、刪除、排序


首先創建一個map對象,並依次放入幾個測試數據

        HashMap<String, Integer> map = new HashMap<String, Integer>(); map.put("One", 1); map.put("Two", 2); map.put("Three", 3);

 

1.遍歷

①方法一

        for (HashMap.Entry<String, Integer> entry : map.entrySet()) { String key = entry.getKey(); Integer val = entry.getValue(); }

②方法二

        for (Iterator<HashMap.Entry<String, Integer>> it = map.entrySet().iterator(); it.hasNext();) { HashMap.Entry<String, Integer> entry = it.next(); String key = entry.getKey(); Integer val = entry.getValue(); }

 

2.刪除

        for (Iterator<HashMap.Entry<String, Integer>> it = map.entrySet().iterator(); it.hasNext(); ) { HashMap.Entry<String, Integer> entry = it.next(); //刪除key值為Two的數據
            if (entry.getKey().equals("Two")) { it.remove(); } }

 

3.排序

        //創建一個用於對yourMap進行排序的list
        List<HashMap.Entry<String, Integer>> list = new ArrayList(yourMap.entrySet()); //提供一個匿名的比較函數對象(從大到小進行輸出)
        Collections.sort(list, new Comparator<HashMap.Entry<String, Integer>>() { public int compare(HashMap.Entry<String, Integer> o1, HashMap.Entry<String, Integer> o2) { return o2.getValue() - o1.getValue(); //這里是從大到小進行排序,如果需從小到大進行排序則將o1和o2互換即可
 } }); //按排序輸出list中的內容
        for (HashMap.Entry<String, Integer> entry : list) { String key = entry.getKey(); Integer val = entry.getValue(); }

 

以上。

 


免責聲明!

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



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