Java Map按照Key和Value排序【转】

package kingtool.sort;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.Iterator;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import java.util.TreeMap;
import java.util.Map.Entry;
/**
 *
 * @author King
 *
 */
public class MapSortTool {
    public static void main(String[] args) {

        Map<String, String> map = new TreeMap<String, String>();
        map.put("4", "2");
        map.put("1", "1");
        map.put("9", "3");
        map.put("8", "6");

//      Map<String, String> resultMap = sortMapByKey(map); //按Key进行排序
        Map<String, String> resultMap = sortMapByValue(map); // 按Value进行排序

        for (Map.Entry<String, String> entry : resultMap.entrySet()) {
            System.out.println(entry.getKey() + " " + entry.getValue());
        }
    }
    /**
     * 使用 Map按key进行排序
     *
     * @param map
     * @return
     */
    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 MapKeyStringComparator());
        sortMap.putAll(map);
        return sortMap;
    }

    /**
     * 使用 Map按value进行排序
     *
     * @param map
     * @return
     */
    public static Map<String, String> sortMapByValue(Map<String, String> oriMap) {
        if (oriMap == null || oriMap.isEmpty()) {
            return null;
        }
        Map<String, String> sortedMap = new LinkedHashMap<String, String>();
        List<Map.Entry<String, String>> entryList = new ArrayList<Map.Entry<String, String>>(oriMap.entrySet());
        Collections.sort(entryList, new MapValueStringComparator());

        Iterator<Map.Entry<String, String>> iter = entryList.iterator();
        Map.Entry<String, String> tmpEntry = null;
        while (iter.hasNext()) {
            tmpEntry = iter.next();
            sortedMap.put(tmpEntry.getKey(), tmpEntry.getValue());
        }
        return sortedMap;
    }

    /**
     * string key升序
     * @author King
     *
     */
    static class MapKeyStringComparator implements Comparator<String>{

        @Override
        public int compare(String str1, String str2) {
            return str1.compareTo(str2);
        }
    }

    /**
     * string value升序
     * @author King
     *
     */
    static class MapValueStringComparator implements Comparator<Map.Entry<String, String>> {

        @Override
        public int compare(Entry<String, String> entry1, Entry<String, String> entry2) {
            return entry1.getValue().compareTo(entry2.getValue());
        }
    }

    /**
     * tip: 样例中没用到<br/>
     * double value降序
     * @author King
     *
     */
    static class MapValueNumberComparator implements Comparator<Map.Entry<String, Double>> {
        @Override
        public int compare(Entry<String, Double> entry1, Entry<String, Double> entry2) {
            return entry1.getValue().compareTo(entry2.getValue());
        }
    }
}
时间: 2024-10-20 00:19:14

Java Map按照Key和Value排序【转】的相关文章

Java Map获取key和value 以及String字符串转List方法

一.问题描述 这里描述两个问题: 1.Java Map获取key和value的方法: 2.String字符串转List的方法: 二.解决方法 1.Java Map获取key和value的方法   2.String字符串转List的方法  

Java Map按键(Key)排序和按值(Value)排序

Map排序的方式有很多种,两种比较常用的方式:按键排序(sort by key), 按值排序(sort by value).1.按键排序jdk内置的java.util包下的TreeMap<K,V>既可满足此类需求,向其构造方法 TreeMap(Comparator<? super K> comparator)  传入我们自定义的比较器即可实现按键排序. Java代码   public class MapSortDemo { public static void main(Strin

Java Map 按Key排序和按Value排序

package test; import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import java.util.HashMap; import java.util.Iterator; import java.util.LinkedHashMap; import java.util.List; import java.util.Map; import java.util.Tr

JAVA map按照key,value比较

import java.util.*; public class MapSortDemo { public static void main(String[] args) { Map<String, String> map = new HashMap<>(); map.put("1", "4");        map.put("3", "3");        map.put("2"

Java Map中key用可变对象会是什么后果?

结论:put之后key变化了在get就get为null了 Scala代码 val map = new mutable.HashMap[java.util.List[String], String]() val key = new util.ArrayList[String]() map.put(key, "value") println(map) println(map.get(key).getOrElse("null")) key.add("11&quo

java Map 迭代key,value 最简洁的方法

import java.util.HashMap; import java.util.Map; public class EntrySets { public static void main(String[] args) { Map<Object, Object> map = new HashMap<Object, Object>(); map.put("k1", "v1"); map.put("k2", "v

JAVA中对list map根据map某个key值进行排序

package test; import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import java.util.HashMap; import java.util.List; import java.util.Map; public class java_ListMapSort { public static void main(String[] args) { // TO

Java中对listmap根据map某个key值进行排序

Collection提供了排序方法sort(),但对于List<Map> 需要根据Map中某一个或某几个Key进行排序,就需要重写sort()方法来实现了: 实现方式如下: public static void main(String[] args) { List<Map<String, String>> list = new ArrayList<Map<String, String>>(); Map<String, String>

c++中map按key和value排序

1 ``` 2 #include<iostream> 3 #include<algorithm> 4 #include<vector> 5 #include<map> 6 #include<set> 7 using namespace std; 8 9 /*按key升序*/ 10 void test01(){ 11 map<string,int,less<string> > map1; 12 map1.insert(pai