Java在线运行

版本:

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

                        
以下是用户最新保存的代码
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 测试功能运行 发布于:2024-03-04 17:18 写出一个完整的声明复数类的iava程序输入2个括号字符串如 (1,2) (34) 发布于:2024-03-03 20:16 这是数据科学与算法 发布于:2024-02-28 02:04 健康和健康很快就会健康和健康 发布于:2024-02-26 16:45 人员信息匹配 发布于:2024-02-24 18:00 构造方法使用 发布于:2024-02-24 16:25 方法的重载 发布于:2024-02-22 12:50 迷宫老鼠问题 发布于:2024-02-21 16:33 类与对象的使用 发布于:2024-02-21 15:32 撒地方大师傅 发布于:2024-02-19 11:16 我的测试代码 发布于:2024-02-19 10:19 java AES 加密 发布于:2024-02-18 16:47 插入元素排序 发布于:2024-02-18 12:42 打印杨辉三角形 发布于:2024-02-18 10:46 冒泡排序法 发布于:2024-02-17 22:28 为数组添加新元素 发布于:2024-02-17 18:21 数组的使用 发布于:2024-02-16 20:21 1-1/2..求和 发布于:2024-02-15 19:58 大小写字母 发布于:2024-02-15 19:45 输出不被5整除的数 发布于:2024-02-15 18:48 提示登陆成功 发布于:2024-02-15 17:21 打印空心金字塔 发布于:2024-02-15 15:52 乘法口诀表 发布于:2024-02-15 14:31 for循环的嵌套使用 发布于:2024-02-15 13:51 [更多]
显示目录

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