Java在线运行

版本:

所属目录
点击了解高性能代码运行API
运行结果
教程手册
代码仓库
极速运行
交互输入
极速运行模式,更高效的运行,点击编辑器上方的运行按钮即刻体验吧。
以下是用户最新保存的代码
for循环嵌套 发布于:2022-11-08 13:58 仿沙卡拉六级梯形金字塔(初版) 发布于:2022-11-08 10:25 测试变量变化 发布于:2022-11-06 22:18 二分查找:查找最后一个小于等于给定值的元素: 发布于:2022-11-06 00:13 二分查找:查找第一个大于等于给定值的元素: 发布于:2022-11-06 00:09 二分查找的变形 :查找最后一个值等于给定值的元素 发布于:2022-11-06 00:02 实现二分查找 发布于:2022-11-05 23:02 输出1-10之间的偶数(while) 发布于:2022-11-07 10:00 输出1-10之间所有偶数(for) 发布于:2022-11-07 10:02 输出1-10之间10个数的和 发布于:2022-11-05 16:06 输出1-10之间的10个整数 发布于:2022-11-05 16:04 跨银行交易系统 发布于:2022-11-05 15:40 收支系统verson 1.0 发布于:2022-11-05 14:09 求1到100奇数的和 发布于:2022-11-05 11:02 测试代码。 发布于:2022-11-04 09:35 交互输入一个三位数,分别输出这个三位数的个位、十位、百位。 发布于:2022-11-03 15:53 输入账户判断 发布于:2022-11-03 15:23 年轻人,你还是太嫩了 发布于:2022-11-03 13:04 空心金字塔 发布于:2022-11-02 15:58 我女神丽丽 发布于:2022-11-01 15:58 计数排序:2 5 3 0 2 3 0 3 发布于:2022-11-01 12:42 桶排序:78 17 39 26 72 94 21 12 23 68 发布于:2022-11-01 11:34 java用treeset集合实现不重复的数列 发布于:2022-11-01 08:42 获取用户信息 发布于:2022-10-31 12:22 ArrayList类银行取款 发布于:2022-10-31 11:54 FinalShell的离线机器码 发布于:2022-10-30 12:06 AAB前身代码 发布于:2022-10-29 20:35 查找AAB类型单词 发布于:2022-10-29 20:21 松岛枫是的肤色饭 发布于:2022-10-28 15:23 二维数组式 发布于:2022-10-26 20:24 java List 排序 数字字符串 发布于:2022-10-25 09:34 网络报文加密解密 发布于:2022-10-24 18:17 字符串变形 发布于:2022-10-24 18:16 归并排序实现 发布于:2022-10-23 22:34 快速排序实现: 发布于:2022-10-23 21:48 混合项目测试 发布于:2022-10-23 21:33 奇偶数之和判断 发布于:2022-10-23 20:25 解题:跳跃游戏(优先队列,大堆) 发布于:2022-10-23 17:03 分治法2-10-15-课堂练习-md.6 发布于:2022-10-20 19:58 java实现员工工资管理系统 发布于:2022-10-19 10:41 回文数递归法 发布于:2022-10-18 22:09 回文数递推法 发布于:2022-10-18 22:08 农民分土地 发布于:2022-10-18 16:07 字符串的输入,字符出现次数 发布于:2022-10-17 20:47 元音字母小写 发布于:2022-10-17 20:12 农民分土地递推实现: 发布于:2022-10-15 13:23 数组累加递推实现: 发布于:2022-10-15 13:15 数组累加递归实现: 发布于:2022-10-15 13:03 农民分土地递归实现: 发布于:2022-10-15 12:55 设计一个输出如下形式数值的递归算法 n n n n n … n … 3 3 3 2 2 1 发布于:2022-10-15 00:58 [更多]
显示目录

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

使用此草稿 删除草稿

  • 00:23
注册登录后可减少验证码的弹出,点击前往 注册 | 登录

皮肤:

运行模式:

嵌入代码 iframe嵌入:


服务器已安装大部分常用的依赖库,但仍会存在一些未被安装的库, 可以通过本窗口立即安装所需依赖库,请确保库名正确,否则无法安装成功。


请输入依赖库的名称:

请选择语言: