Java代码信息

运行结果
教程手册
代码仓库
点击编辑器上方的运行按钮,会在此处显示运行结果。
以下是用户最新保存的代码
API random (摇塞子游戏) 发布于:2020-08-13 15:46 主函数-- 发布于:2020-08-10 17:17 主函数-- 发布于:2020-08-10 17:16 主函数-- 发布于:2020-08-10 17:16 定义类-学生-继承自人类 发布于:2020-08-10 17:11 自动截取日本名称 发布于:2020-08-08 12:10 Base64 发布于:2020-08-07 14:37 池塘问题,待修改 发布于:2020-08-10 14:36 自动截取日本名称 发布于:2020-08-08 11:57 API random (摇塞子游戏) 发布于:2020-08-06 15:05 Nginx log escape 发布于:2020-08-07 15:55 《算法》练习1.1.6 发布于:2020-08-04 21:29 排序... 发布于:2020-08-04 22:10 斐波那契函数 发布于:2020-08-04 15:37 《算法》练习1.1.5 发布于:2020-08-03 23:41 《算法》练习1.1.3 发布于:2020-08-03 22:13 《算法》练习1.1.2 发布于:2020-08-03 20:37 《算法》练习1.1.1 发布于:2020-08-03 19:24 jvaaaaa 发布于:2020-08-03 14:16 练习加深印象 发布于:2020-08-03 13:54 测试显目1 发布于:2020-07-31 16:20 hh-test 发布于:2020-07-30 10:28 聊天小工具。 发布于:2020-07-30 09:40 使用for循环嵌套实现99乘法表。 发布于:2020-07-29 21:22 for循环嵌套练习。 发布于:2020-07-29 19:55 加深三目运算符练习。 发布于:2020-07-29 13:50 逻辑运算符加深印象。 发布于:2020-07-29 13:38 写着玩的东西 发布于:2020-07-30 11:26 算算舍罕王给了多少粒麦子 发布于:2020-07-27 22:48 leetcode 发布于:2020-07-27 01:29 java练习输出打印1到100的奇数和偶数。 发布于:2020-07-25 15:03 test1 发布于:2020-07-24 14:16 第三届天命杯Roll图/模式 发布于:2020-07-23 20:17 用if和else循环判断是雨天还是睛天,男女的状态 发布于:2020-07-23 18:23 用switch循环判断男女还有天气 发布于:2020-07-23 18:22 用switch循环判断输入的数值是星期几。 发布于:2020-07-23 18:22 这个源码是表示商场打折判断写法 发布于:2020-07-23 18:21 这个源码是写用if判断成绩的 发布于:2020-07-23 18:19 用来正实是否是质数的写法 发布于:2020-07-23 18:17 一个登陆功能小文本 发布于:2020-07-23 18:15 用一个递归和一个for循环来表示两个数据 发布于:2020-07-23 18:13 java豪宅房租计算脚本 发布于:2020-07-23 17:49 java练习 发布于:2020-07-23 16:28 输出语句,是System.out.println的... 发布于:2020-07-23 10:27 测试三元运算符 发布于:2020-07-22 19:35 【基础】-数据结构 发布于:2020-07-23 22:40 测试数据类型之间的自动转换和强制转换 发布于:2020-07-22 10:32 java Queue 应用,先进先出用法实例, ... 发布于:2020-07-21 17:16 服务器代码 发布于:2020-07-20 10:59 客户端代码 发布于:2020-07-20 11:53 [更多]
显示目录

Java 8 –对Map进行排序

sorting sorting

Few Java 8 Stream examples to sort a Map

1. Sort by Key

SortByKeyExample.java

package com.mkyong.test;

import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.Map;

public class SortByKeyExample {

    public static void main(String[] argv) {

        Map<String, Integer> unsortMap = new HashMap<>();
        unsortMap.put("z", 10);
        unsortMap.put("b", 5);
        unsortMap.put("a", 6);
        unsortMap.put("c", 20);
        unsortMap.put("d", 1);
        unsortMap.put("e", 7);
        unsortMap.put("y", 8);
        unsortMap.put("n", 99);
        unsortMap.put("j", 50);
        unsortMap.put("m", 2);
        unsortMap.put("f", 9);

        System.out.println("Original...");
        System.out.println(unsortMap);

        Map<String, Integer> result = new LinkedHashMap<>();

        //sort by key, a,b,c..., and put it into the "result" map 
        unsortMap.entrySet().stream()
                .sorted(Map.Entry.<String, Integer>comparingByKey())
                .forEachOrdered(x -> result.put(x.getKey(), x.getValue()));

        System.out.println("Sorted...");
        System.out.println(result);

    }

}

Output

Original...
{a=6, b=5, c=20, d=1, e=7, f=9, y=8, z=10, j=50, m=2, n=99}

Sorted...
{a=6, b=5, c=20, d=1, e=7, f=9, j=50, m=2, n=99, y=8, z=10}

2. Sort by Value

SortByValueExample.java

package com.mkyong.test;

import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.Map;

public class SortByValueExample {

    public static void main(String[] argv) {

        Map<String, Integer> unsortMap = new HashMap<>();
        unsortMap.put("z", 10);
        unsortMap.put("b", 5);
        unsortMap.put("a", 6);
        unsortMap.put("c", 20);
        unsortMap.put("d", 1);
        unsortMap.put("e", 7);
        unsortMap.put("y", 8);
        unsortMap.put("n", 99);
        unsortMap.put("j", 50);
        unsortMap.put("m", 2);
        unsortMap.put("f", 9);

        System.out.println("Original...");
        System.out.println(unsortMap);

        Map<String, Integer> result = new LinkedHashMap<>();

        //sort by value, and reserve, 10,9,8,7,6...
        unsortMap.entrySet().stream()
                .sorted(Map.Entry.<String, Integer>comparingByValue().reversed())
                .forEachOrdered(x -> result.put(x.getKey(), x.getValue()));

        System.out.println("Sorted...");
        System.out.println(result);

    }

}

Output

Original...
{a=6, b=5, c=20, d=1, e=7, f=9, y=8, z=10, j=50, m=2, n=99}

Sorted...
{n=99, j=50, c=20, z=10, f=9, y=8, e=7, a=6, b=5, m=2, d=1}

3. Generic Example

Create a generic method to sort a Map.

SortByGenericExample.java

package com.mkyong.test;

import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.Map;
import java.util.stream.Stream;

public class SortByGenericExample {

    public static void main(String[] argv) {

        Map<String, Integer> unsortMap = new HashMap<>();
        unsortMap.put("z", 10);
        unsortMap.put("b", 5);
        unsortMap.put("a", 6);
        unsortMap.put("c", 20);
        unsortMap.put("d", 1);
        unsortMap.put("e", 7);
        unsortMap.put("y", 8);
        unsortMap.put("n", 99);
        unsortMap.put("j", 50);
        unsortMap.put("m", 2);
        unsortMap.put("f", 9);

        System.out.println("Original...");
        System.out.println(unsortMap);

        System.out.println("Sort By Key...");
        Map<String, Integer> resultKey = compareByKey(unsortMap);
        System.out.println(resultKey);

        System.out.println("Sort By Value...");
        Map<String, Integer> resultValue = compareByValue(unsortMap);
        System.out.println(resultValue);
    }

    //Reference from java.util.Map source code, try dig inside, many generic examples.
    public static <K, V extends Comparable<? super V>> Map<K, V> compareByValue(Map<K, V> map) {

        Map<K, V> result = new LinkedHashMap<>();

        Stream<Map.Entry<K, V>> mapInStream = map.entrySet().stream();

        mapInStream.sorted(Map.Entry.comparingByValue())
                .forEachOrdered(x -> result.put(x.getKey(), x.getValue()));

        return result;

    }

    public static <K extends Comparable<? super K>, V> Map<K, V> compareByKey(Map<K, V> map) {

        Map<K, V> result = new LinkedHashMap<>();
        Stream<Map.Entry<K, V>> mapInStream = map.entrySet().stream();

        mapInStream.sorted(Map.Entry.comparingByKey())
                .forEachOrdered(x -> result.put(x.getKey(), x.getValue()));

        return result;

    }

}

Output

Original...
{a=6, b=5, c=20, d=1, e=7, f=9, y=8, z=10, j=50, m=2, n=99}

Sort By Key...
{a=6, b=5, c=20, d=1, e=7, f=9, j=50, m=2, n=99, y=8, z=10}

Sort By Value...
{d=1, m=2, b=5, a=6, e=7, y=8, f=9, z=10, c=20, j=50, n=99}

Note
Not using Java 8? Try this classic way to sort a Map in Java.

References

  1. How to sort a Map in Java
  2. More Fun with Wildcards
  3. Collections.sort() signature
  4. Difference between and in Java
由JSRUN为你提供的Java在线工具
        JSRUN提供的Java在线运行,Java 在线编译工具,基于linux操作系统环境提供线上编译和线上运行,具有运行快速,运行结果与常用开发、生产环境保持一致的特点。

title

使用此草稿 删除草稿