java map 快速根据value排序
    		       		warning:
    		            这篇文章距离上次修改已过453天,其中的内容可能已经有所变动。
    		        
        		                
                在Java中,可以使用TreeMap来根据Map的值进行快速排序。以下是一个示例代码,它将Map中的元素按照值进行降序排序:
import java.util.*;
 
public class SortMapByValue {
    public static void main(String[] args) {
        // 创建一个Map
        Map<String, Integer> map = new HashMap<>();
        map.put("apple", 10);
        map.put("orange", 20);
        map.put("banana", 15);
 
        // 使用TreeMap对Map的值进行排序
        Map<String, Integer> sortedMap = new TreeMap<>(
            new Comparator<String>() {
                @Override
                public int compare(String key1, String key2) {
                    return map.get(key2) - map.get(key1); // 降序排序
                }
            }
        );
        sortedMap.putAll(map);
 
        // 打印排序后的Map
        for (Map.Entry<String, Integer> entry : sortedMap.entrySet()) {
            System.out.println(entry.getKey() + " : " + entry.getValue());
        }
    }
}这段代码首先创建了一个包含三个键值对的HashMap。然后,使用一个TreeMap,其比较器是一个匿名内部类,用于比较键。在比较器中,它使用了原始Map的键来比较它们的值,并按照Map值的降序来排列键。最后,使用一个循环将排序后的键值对打印出来。
评论已关闭