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