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