根据Map的键和值进行排序的方法

根据键

需要使用TreeMap和Comparator类的compareTo()方法。

import java.util.Comparator;
import java.util.Map;
import java.util.TreeMap;

public class Test_sort{
    public static void main(String[] args) {
        Map<String,String>map = new TreeMap<>(new Comparator<String>() {
            @Override
            public int compare(String o1, String o2) {
                //降序
                //return o2.compareTo(o1);
                //升序
                return o1.compareTo(o2);
            }
        });

        map.put("2","Language");
        map.put("1","Java Language");
        map.put("3","C Language");

        System.out.println(map);
    }
}

其中,对于map的定义可以写成Lambda表达式

		Map<String,String>map = new TreeMap<>((o1, o2) -> {
            //降序
            //return o2.compareTo(o1);
            //升序
            return o1.compareTo(o2);
        });

根据值

需要使用Collections.sort()和Lambda表达式
Lambda表达式1
Lambda表达式2

import java.util.*;

public class Test_sort {
    public static void main(String[] args) {
        Map<String, String> map = new HashMap<>();

        map.put("A", "33");
        map.put("B", "31");
        map.put("C", "35");

        List<Map.Entry<String, String>> list = new ArrayList<>(map.entrySet());
        Collections.sort(list, new Comparator<Map.Entry<String, String>>() {
            @Override
            public int compare(Map.Entry<String, String> o1, Map.Entry<String, String> o2) {
                int compare = (o1.getValue()).compareTo(o2.getValue());
                //升序
                return compare;
            	//降序
            	//return -compare;
            }
        });

        for (Map.Entry<String, String> maps : list) {
            System.out.println(maps.getKey() + " " + maps.getValue());
        }
    }
}

实际上这种操作并没有对map本身排序,发生顺序变化的是list。

发布了19 篇原创文章 · 获赞 8 · 访问量 1660

猜你喜欢

转载自blog.csdn.net/weixin_46192593/article/details/104987354
今日推荐