转载:http://www.oschina.net/code/snippet_12_546?from=rss
package net.oschina.tester; import java.util.*; /** * 根据 HashMap 的 value 进行排序 * @author Winter Lau * @date 2009-11-24 下午01:35:37 */ public class SortByValueDemo { public static void main(String[] args) { HashMap<String, Integer> datas = new HashMap<String, Integer>(){{ put("Winter Lau", 100); put("Yier", 150); put("Nothing", 30); put("Zolo", 330); }}; ByValueComparator bvc = new ByValueComparator(datas); //第一种方法 TreeMap<String, Integer> sorted_map = new TreeMap<String, Integer>(bvc); sorted_map.putAll(datas); for(String name : sorted_map.keySet()){ System.out.printf("%s -> %d\n", name, datas.get(name)); } //第二种方法 List<String> keys = new ArrayList<String>(datas.keySet()); Collections.sort(keys, bvc); for(String key : keys) { System.out.printf("%s -> %d\n", key, datas.get(key)); } } static class ByValueComparator implements Comparator<String> { HashMap<String, Integer> base_map; public ByValueComparator(HashMap<String, Integer> base_map) { this.base_map = base_map; } public int compare(String arg0, String arg1) { if (!base_map.containsKey(arg0) || !base_map.containsKey(arg1)) { return 0; } if (base_map.get(arg0) < base_map.get(arg1)) { return 1; } else if (base_map.get(arg0) == base_map.get(arg1)) { return 0; } else { return -1; } } } }