Java在线运行

版本:

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

                        
以下是用户最新保存的代码
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 dowhile循环的使用 发布于:2024-02-15 13:21 for循环count 发布于:2024-02-15 11:55 switch判断成绩合格 发布于:2024-02-15 11:17 if else控制语句 发布于:2024-02-15 08:46 发布于:2024-02-14 21:51 Scanner扫描器 发布于:2024-02-14 18:40 java学习 发布于:2024-02-08 01:05 我的画图脚本 发布于:2024-02-06 22:07 小红书的签名算法 发布于:2024-02-06 18:08 输入任意数字,获取大于该数字的偶数 发布于:2024-02-06 10:24 java数字排序程序 发布于:2024-01-31 14:44 23544符合法规和国家与iu哦 发布于:2024-01-31 09:55 归并排序算法 发布于:2024-01-31 09:04 加密算法-SHA256 发布于:2024-01-30 14:27 温度转换程序 发布于:2024-01-31 14:40 插入排序算法 发布于:2024-01-25 22:01 数组里有两种数是奇数个,其他都是偶数个,要求时间复杂度O(n),空间复杂度O(n) 发布于:2024-01-25 21:52 冒泡排序算法 发布于:2024-01-25 09:27 选择排序算法 发布于:2024-01-25 09:18 [更多]
显示目录

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