java利用list的value進行排序
java中有排序的方法Collections.sort;可以直接利用這個排序list;
eg:
List<Map<String,String>> listmap=new ArrayList<Map<String,String>>();
for(int i=5;i>0;i--){
Map map=new HashMap<String, String>();
map.put("ff", i+"");
listmap.add(map);
}
Collections.sort(listmap,new Comparator<Map<String,String>>() {
public int compare(Map<String, String> o1, Map<String, String> o2) {
// TODO Auto-generated method stub
return o1.get("ff").compareTo(o2.get("ff"));
}
});
如果Map的value是中文,會自動按照拼音順序進行排序
但是如果想自定義排序規則,比如數字0,1,2。不倒敘也不順序,而是自定義一個規則,然後排序。
首先定義一個排序規則,比如讓它按照1,0,2的順序
//排序規則
final List<String> rules = new ArrayList<>();
rules.add("1");
rules.add("0");
rules.add("2");
然後查詢List中的值在rules中的位置,從而排序;
Collections.sort(listmap,new Comparator<Map<String,String>>() {
public int compare(Map<String, String> o1, Map<String, String> o2) {
// TODO Auto-generated method stub
return rules.indexOf(o1.get("ff")-rules.indexOf(o2.get("ff")));
}
});