Java在线运行

版本:

所属目录
点击了解高性能代码运行API
运行结果
教程手册
代码仓库
极速运行
终端运行
图形+终端

                        
以下是用户最新保存的代码
DES加密 发布于:2024-05-23 12:03 测试代码! 发布于:2024-05-21 16:57 java字符匹配代码 发布于:2024-05-21 13:17 加密撒阿斯顿 发布于:2024-05-21 06:26 rsa 加密的Java代码 发布于:2024-05-19 13:48 黎明杀机技能随机 发布于:2024-05-19 09:13 随机数获取 发布于:2024-05-18 21:35 随机数获取 发布于:2024-05-18 21:17 测试加密算法 发布于:2024-05-18 19:17 内部类代码等 发布于:2024-05-17 11:10 父类引用调用子类 发布于:2024-05-16 08:33 Java第一个语言 发布于:2024-05-15 18:45 HG6201T 超级密码破解. 发布于:2024-05-12 15:50 围圈站人,每数到3的被淘汰,最后剩下的人是第几个 发布于:2024-05-12 10:13 定泥浆泵压力的最小值和最大值 发布于:2024-05-09 16:53 AES 解密: 授权时间 发布于:2024-05-08 20:39 离散数学1 选做1 发布于:2024-05-08 11:15 java bigInteger encodes 发布于:2024-05-07 21:25 五子棋游戏 发布于:2024-05-04 23:37 贪心算法求解 发布于:2024-05-01 15:03 王兵大Sb 发布于:2024-04-29 20:59 Java算法测试 发布于:2024-04-27 19:35 第一个测试类 发布于:2024-04-27 17:09 自己写java的string类 发布于:2024-04-27 14:35 Hello java 发布于:2024-04-24 01:42 每个查询任务应该都有自己唯一的任务id,遇到这种情况一般是通过异常处理,当遇到用户点击取消查询的时候,通过java强制取消任务管理器的任务,在任务中断以后,检查是否关闭需要关闭的资源,列如数据库链接等问题 发布于:2024-04-22 23:59 hello world 发布于:2024-04-22 10:39 java-BigDecimal运算保留两位小数更准确,符合四舍五入 发布于:2024-04-19 21:39 dfsd ds东方闪电的发生发多少发多少多少发生的大多数f第三方多少 发布于:2024-04-18 14:12 我的第一个测试程序 发布于:2024-04-17 21:29 1-2020中含有2的数字 发布于:2024-04-12 21:26 转换大小写 发布于:2024-04-12 20:53 阶乘相加求和,保留后9位 发布于:2024-04-12 15:10 计数器计数 发布于:2024-04-11 21:41 类变量赋值方法 发布于:2024-04-11 21:27 希尔排序算法 发布于:2024-04-11 09:10 二分法查找 发布于:2024-04-11 08:57 冒泡排序算法 发布于:2024-04-10 11:14 代码片段-正则表达式提取特定文本 发布于:2024-04-02 17:58 Java代码 发布于:2024-03-30 17:02 三角形判定 发布于:2024-03-29 10:34 1hello world 发布于:2024-03-27 00:30 jia fa ji suan 发布于:2024-03-21 16:11 sudoku solver (not completed) 发布于:2024-03-16 23:48 java第一次作业 发布于:2024-03-15 00:22 获取个十百 发布于:2024-03-14 23:38 MD5编码规则 与时间格式化 发布于:2024-03-13 14:18 传递继承的示例 发布于:2024-03-12 18:10 斐波那契数列 发布于:2024-03-12 17:36 DS 代码示例保存。 发布于:2024-03-06 08:47 [更多]
显示目录

Java 8 –对Map进行排序



学习嵌入式的绝佳套件,esp8266开源小电视成品,比自己去买开发板+屏幕还要便宜,省去了焊接不当搞坏的风险。 蜂鸣版+触控升级仅36元,更强的硬件、价格全网最低。

点击购买 固件广场

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操作系统环境提供线上编译和线上运行,具有运行快速,运行结果与常用开发、生产环境保持一致的特点。
yout