項目應用小趣味(二):通過比較器Comparator來實現排序

1,問題描述:
需求中突然想要數據中,同類型的數據有序。數據類型是List<Map<Key,Value>>數據量比較適中。

2,問題分析和解決
問題是把List裏面Map中key=”xxx”的數據進行排序。
通常的排序在List層排序,裏面再包裹着Map,Map裏面又對一類型的數據排序,那麼就可以通過Comparator比較器接口來實現。

//list<Map<String,object>>按照一個key的value值進行排序
    public static void listMapSort() {
        //List<Map<String,String>> list = new ArrayList<Map<String,String>>();不用泛型效率高:項目中用的是泛型
        List<Map<String,Object>> list = new ArrayList<Map<String,Object>>();
        //製造一些數據(看文章最後)
        makeData(list);
        System.out.println("------------------------------排序前----------------------------");
        for(Map<String,Object> accMap:list) {
            String str = accMap.get("a").toString();
            System.out.println(str);
        }
         //Collections.sort(list, comparator);
         //然後通過比較器來實現排序
         Collections.sort(list,new Comparator<Map<String,Object>>() {
            //升序排序:key="a"
            public int compare(Map<String, Object> o1,
                  Map<String, Object> o2) {
                  return o1.get("a").toString().compareTo(o2.get("a").toString());
                }

            });
        System.out.println("------------------------------排序後----------------------------");
        for(Map<String,Object> accMap:list) {
            String str = accMap.get("a").toString();
            System.out.println(str);
        }
   }

打印結果:
------------------------------排序前----------------------------
ddddd
bbbbb
aaaaa
ccccc
382563100010302
382563100010301
382563100057801
382563100017401
------------------------------排序後----------------------------
382563100010301
382563100010302
382563100017401
382563100057801
aaaaa
bbbbb
ccccc
ddddd

3,項目應用

按照上述方式,服務器拋java.lang.ClassNotFoundException 異常。原因是往服務器少傳了一個class文件。此段代碼再Java類中會生成兩個class文件(內部類會生成一個是空的class文件),都要上傳到服務器。如果空class文件不上傳就會報異常。

Comparator是比較器接口
我們若需要控制某個類的次序,而該類本身不支持排序(即沒有實現Comparable接口);
那麼,我們可以建立一個“該類的比較器”來進行排序。這個“比較器”只需要實現Comparator接口即可。也就是說,我們可以通過“實現Comparator類來新建一個比較器”,然後通過該比較器對類進行排序。

手動製造一些直觀性的數據

public static void makeData(List<Map<String,Object>> list) {
            Map<String, Object> map1 = new HashMap<String, Object>();
            map1.put("b", "12");
            map1.put("a", "ddddd");
            Map<String, Object> map2 = new HashMap<String, Object>();
            map2.put("c", "2w");
            map2.put("a", "bbbbb");
            Map<String, Object> map3 = new HashMap<String, Object>();
            map3.put("s", "ww");
            map3.put("a", "aaaaa");
            Map<String, Object> map4 = new HashMap<String, Object>();
            map4.put("a", "ccccc");
            Map<String, Object> map5 = new HashMap<String, Object>();
            map5.put("s", "fff");
            map5.put("a", "382563100010302");
            Map<String, Object> map6 = new HashMap<String, Object>();
            map6.put("a", "382563100010301");
            Map<String, Object> map7 = new HashMap<String, Object>();
            map7.put("a", "382563100057801");
            Map<String, Object> map8 = new HashMap<String, Object>();
            map8.put("a", "382563100017401");
            list.add(map1);
            list.add(map2);
            list.add(map3);
            list.add(map4);list.add(map5);list.add(map6);list.add(map7);list.add(map8);
        }
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章