- package Map;
- import java.util.ArrayList;
- import java.util.Collections;
- import java.util.Comparator;
- import java.util.List;
- import java.util.Map;
- import java.util.Map.Entry;
- import java.util.TreeMap;
- public class SortMap {
- public static void main(String[] args) {
- Map map=new TreeMap ();
- map.put("圖書" , 4);
- map.put("音像" , 6);
- map.put("素材" , 9);
- map.put("音樂" , 8);
- map.put("影視" , 7);
- map.put("動漫" , 4);
- map.put("歌曲" , 3);
- map.put("圖片" , 2);
- map.put("圖標" , 6);
- ArrayList<Map.Entry<String,Integer>> entries= sortMap(map);
- for( int i=0;i<5;i++){
- System. out.print(entries.get(i).getKey()+":" +entries.get(i).getValue());
- }
- }
- public static ArrayList<Map.Entry<String,Integer>> sortMap(Map map){
- List<Map.Entry<String, Integer>> entries = new ArrayList<Map.Entry<String, Integer>>(map.entrySet());
- Collections.sort(entries, new Comparator<Map.Entry<String, Integer>>() {
- public int compare(Map.Entry<String, Integer> obj1 , Map.Entry<String, Integer> obj2) {
- return obj2.getValue() - obj1.getValue();
- }
- });
- return (ArrayList<Entry<String, Integer>>) entries;
- }
- }
- 此時是按照降序排序,如果想升序排序,則Comparator的 返回 改爲obj1.getValue() - obj2.getValue();即可
總結:由於TreeMap主要是針對key進行默認排序的,但是有的時候我們需要對value進行排序,這時候主要採取的策略是 將map變爲List,然後利用Collections.sort進行排序,同時重寫Comparator方法,即可。
java對map中value的排序
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.