package com.cute.test;

import java.util.Comparator;
import java.util.Map;
import java.util.TreeMap;

public class SortMapTest {

public static void main(String[] args) {
Map<String, String> tmap = new TreeMap<String, String>();
tmap.put("abc", "2");
tmap.put("ace", "3");
tmap.put("cef", "2");
tmap.put("Weight", "6");
tmap.put("BLue", "6");
tmap.put("BLUe", "6");

//对map利用key排序
Map<String, String> resMap = sortMapByKey(tmap);

for (Map.Entry<String, String> entry : resMap.entrySet()) {
System.out.println(entry.getKey() + " " + entry.getValue());
}
}

/**
* 让 Map按key进行排序
*/
public static Map<String, String> sortMapByKey(Map<String, String> map) {
if (map == null || map.isEmpty()) {
return null;
}
Map<String, String> sortMap = new TreeMap<String, String>(new MapKeyComparator());
sortMap.putAll(map);
return sortMap;
}
}

//实现一个比较器类

class MapKeyComparator implements Comparator<String> {

@Override
public int compare(String s1, String s2) {
return s1.compareTo(s2); //从小到大排序
}
}

输出结果:

BLUe 6

BLue 6

Weight 6

abc 2

ace 3

cef 2