[每日知识点] lambda表达式map排序

JAVA 8之后添加了lambda表达式一直没有系统学习 
先记录一下map 利用lambda表达式排序

import java.util.Collections;
import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.Map;
import java.util.stream.Collectors;

import static java.util.Map.Entry.comparingByKey;
import static java.util.Map.Entry.comparingByValue;
import static java.util.stream.Collectors.toMap;

public class TestMap {
    public static void main(String[] args) {
        Map maps = new HashMap<>();
        maps.put("wzn",30);
        maps.put("xhf",29);
        maps.put("as", 1);
        maps.put("bj",21);
        System.out.println("未排序数据:" +maps.toString());
        LinkedHashMap collect1 = maps.entrySet().stream().sorted(comparingByValue()).collect(toMap(Map.Entry::getKey,Map.Entry::getValue, (e1, e2) -> e2, LinkedHashMap::new));
        System.out.println("正序排序数据:" +collect1.toString());
        LinkedHashMap collect2 = maps.entrySet().stream().sorted(Collections.reverseOrder(comparingByValue())).collect(toMap(Map.Entry::getKey, Map.Entry::getValue, (e1, e2) -> e2, LinkedHashMap::new));
        System.out.println("倒序排序数据:" +collect2.toString());
        LinkedHashMap collect3 = maps.entrySet().stream().sorted(comparingByKey()).collect(toMap(Map.Entry::getKey,Map.Entry::getValue, (e1, e2) -> e2, LinkedHashMap::new));
        System.out.println("按key 排序"+collect3.toString());
    }
}

思路整理:

利用map内部类entry 转换成stream流 sorted()方法继续排序(Map.Entry 下有提供好的排序方法 按照key /value排序)排序完成转换成map 利用linkedHashMap保证有序性。

 

你可能感兴趣的:(java基础,Map,Lambda)