国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

遍歷Map的兩種方法(有排序)

2019-11-15 00:21:40
字體:
來源:轉載
供稿:網友
遍歷Map的兩種方法(有排序)

初始化一個map

Map<String, String> map = new HashMap<String, String>();map.put("1", "hell");map.put("2", "hello");map.put("3", "hel");map.put("4", "hello");

1、第一種方式,普遍使用

Set<String> keySet = map.keySet();for (String key : keySet) {     System.out.Set<Map.Entry<String,String>> entySet =  map.entrySet();for (Map.Entry<String, String> entry : entySet) {System.out.println("key= " + entry.getKey() + " and value= "+ entry.getValue());}

實驗發現輸出的順序是亂的,排個序吧

1、按照key值排序

首先寫個排序類

private static class KeyComparator implements        Comparator<Map.Entry<String, String>> {    public int compare(Map.Entry<String, String> m,            Map.Entry<String, String> n) {        return m.getKey().compareTo(n.getKey());    }}

把數據放在list里邊才可以使用

List<Map.Entry<String, String>> list = new ArrayList<Map.Entry<String, String>>();list.addAll(map.entrySet());KeyComparator kc = new KeyComparator();Collections.sort(list, kc);for (Iterator<Map.Entry<String, String>> it = list.iterator(); it        .hasNext();) {    System.out.println(it.next());}

2、按照Value值排序

private static class ValueComparator implements        Comparator<Map.Entry<String, String>> {    public int compare(Map.Entry<String, String> m,            Map.Entry<String, String> n) {        return m.getValue().compareTo(n.getValue());    }}

排序輸出

list.clear();list.addAll(map.entrySet());ValueComparator vc = new ValueComparator();Collections.sort(list, vc);for (Iterator<Map.Entry<String, String>> it = list.iterator();     it.hasNext();) {    System.out.println(it.next());}

Tips: 如有錯誤請指出,我會及時修改


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 光泽县| 亳州市| 云南省| 浮梁县| 札达县| 泰宁县| 滨州市| 东兴市| 灵山县| 安义县| 株洲县| 婺源县| 进贤县| 囊谦县| 衡阳县| 麦盖提县| 遵义县| 福清市| 晋江市| 大冶市| 东山县| 格尔木市| 泽州县| 嘉兴市| 大足县| 泽库县| 泾川县| 周口市| 霍山县| 深州市| 新民市| 拜城县| 台江县| 铜山县| 手游| 陆川县| 兴安县| 靖远县| 奈曼旗| 克拉玛依市| 吉首市|