Java Collection How to - Sort HashMap by Value








Question

We would like to know how to sort HashMap by Value.

Answer

import java.util.Collections;
import java.util.Comparator;
import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
//w  w w .ja v a 2s . c  o m
class MyComparator implements Comparator<Entry<String, Integer>> {
  public int compare(Entry<String, Integer> o1, Entry<String, Integer> o2) {
    return o1.getValue().compareTo(o2.getValue());
  }
}

class Util {
  public static Map<String, Integer> sortByComparator(
      Map<String, Integer> unsortMap) {

    List<Entry<String, Integer>> list = new LinkedList<Entry<String, Integer>>(
        unsortMap.entrySet());

    Collections.sort(list, new MyComparator());

    Map<String, Integer> sortedMap = new LinkedHashMap<String, Integer>();
    for (Entry<String, Integer> entry : list) {
      sortedMap.put(entry.getKey(), entry.getValue());
    }
    return sortedMap;
  }
}

public class Main {

  public static void main(String[] args) {
    Map<String, Integer> unsortMap = new HashMap<String, Integer>();
    unsortMap.put("B", 5);
    unsortMap.put("A", 8);
    unsortMap.put("D", 2);
    unsortMap.put("C", 7);

    System.out.println("Before sorting......");
    System.out.println(unsortMap);

    Map<String, Integer> sortedMapAsc = Util.sortByComparator(unsortMap);
    System.out.println(sortedMapAsc);
  }
}

The code above generates the following result.