Java中 List 集合,通过 Stream 流进行排序总结
一、数据准备
public class OrderTest {private String channelCode;private BigDecimal rate;// 省略 getter、setter、toString()、constructor
}
List<OrderTest> orderTestList = new ArrayList<>();OrderTest z09 = new OrderTest("Z09", new BigDecimal("7.6677"));OrderTest B2C = new OrderTest("B2C", new BigDecimal("5.6666"));OrderTest Z04 = new OrderTest("Z04", new BigDecimal("4.3137"));OrderTest ALL = new OrderTest("ALL", new BigDecimal("4.3137"));OrderTest ALL1 = new OrderTest("ALL", new BigDecimal("4.5137"));// 演示多字段排序使用OrderTest z091 = new OrderTest("Z09", new BigDecimal("7.6671"));// 演示给 null 值排序用OrderTest z092 = new OrderTest("Z09", null);OrderTest B2C1 = new OrderTest("B2C", new BigDecimal("5.6666"));OrderTest Z041 = new OrderTest("Z04", null);orderTestList.add(z09);orderTestList.add(z091);orderTestList.add(B2C);orderTestList.add(Z04);orderTestList.add(ALL);orderTestList.add(ALL1);
二、单字段排序
2.1、升序
list.stram().sorted(Comparator.Comparing(YourClass::Class's Field)
System.out.println("----------------------------------------------");System.out.println("只按照 channelCode 升序排序:");List<OrderTest> channelAsc =orderTestList.stream().sorted(Comparator.comparing(OrderTest::getChannelCode)).collect(Collectors.toList());channelAsc.forEach(System.out::println);
结果:

2.2、降序
list.stram().sorted(Comparator.Comparing(YourClass::Class's Field, Comparator.reverseOrder())
System.out.println("----------------------------------------------");System.out.println("只按照 channelCode 降序排序:");List<OrderTest> channelDesc =orderTestList.stream().sorted(Comparator.comparing(OrderTest::getChannelCode, Comparator.reverseOrder())).collect(Collectors.toList());channelDesc.forEach(System.out::println);
结果:

二、多字段排序
利用的是 thenComparing():
升序 thenComparing(YourClass::Class's Field),
降序 thenComparing(YourClass::Class's Field, Comparator.reverseOrder())。注意: 使用 thenComparing(YourClass::Class's Field).reversed() 的时候要注意排序要求,
如果先按照 A 字段升序 B 字段升序的话,使用 reversed() 之后的结果是对 A 降序 B 降序。
System.out.println("----------------------------------------------");System.out.println("先按照 channelCode 升序,再按照 rate 升序排序:");List<OrderTest> channelCodeAscRateAscList =orderTestList.stream().sorted(Comparator.comparing(OrderTest::getChannelCode).thenComparing(OrderTest::getRate)).collect(Collectors.toList());channelCodeAscRateAscList.forEach(System.out::println);
结果

先按照 channelCode 将序,再按照 rate 升序将序,使用 reversed():
System.out.println("----------------------------------------------");System.out.println("先按照 channelCode 将序,再按照 rate 将序排序,使用 reversed():");List<OrderTest> channelCodeAscRateAscWithReversedList =orderTestList.stream().sorted(Comparator.comparing(OrderTest::getChannelCode).thenComparing(OrderTest::getRate).reversed()).collect(Collectors.toList());channelCodeAscRateAscWithReversedList.forEach(System.out::println);
结果

三、对 null 值处理
Comparator.nullsFirst(Comparator.reverseOrder()) -- null排在前面,reverseOrder是倒序,升序用naturalOrderComparator.nullsLast(Comparator.reverseOrder()) -- null排在后面,reverseOrder是倒序,升序用naturalOrder
orderTestList.add(new OrderTest(("Z09")));orderTestList.add(new OrderTest(("B2C")));orderTestList.add(new OrderTest(("Z04")));System.out.println("----------------------------------------------");System.out.println("先按照 channelCode 升序,再按照 rate 降序并且 null 值放前面排序:");List<OrderTest> channelCodeAscRateDescNullFirstList = orderTestList.stream().sorted(Comparator.comparing(OrderTest::getChannelCode).thenComparing(OrderTest::getRate, Comparator.nullsFirst(Comparator.reverseOrder()))).collect(Collectors.toList());channelCodeAscRateDescNullFirstList.forEach(System.out::println);
结果

四、对排序字段个数不固定的情况,如何排序
需求:排序字段个数不确定,如何实现动态排序?
伪代码示例:
Comparator<SurgUnArrangeResponse> comparing = null;for (int i = 0; i < dictItemList.size(); i++) {String cd = dictItemList.get(i).getCd();if (i == 0) {// 首次排序comparing = getComparingByDictCd(cd, null);} else {// 第二次排序及以上comparing = getComparingByDictCd(cd, comparing);}}// comparing 比较器,保存了排序的规则,responseList 是被排序的集合responseList = responseList.stream().sorted(comparing).collect(Collectors.toList());// getComparingByDictCd 方法private Comparator<SurgUnArrangeResponse> getComparingByDictCd(String dictCd,
Comparator<SurgUnArrangeResponse> result = null;switch (dictCd) {case "age":result = comparing == null ? Comparator.comparing(SurgUnArrangeResponse::getAge, Comparator.nullsLast(Comparator.reverseOrder())) :comparing.thenComparing(SurgUnArrangeResponse::getAge, Comparator.nullsLast(Comparator.reverseOrder()));break;....}return result;}
相关文章:
Java中 List 集合,通过 Stream 流进行排序总结
一、数据准备 public class OrderTest {private String channelCode;private BigDecimal rate;// 省略 getter、setter、toString()、constructor }List<OrderTest> orderTestList new ArrayList<>();OrderTest z09 new OrderTest("Z09", new BigDeci…...
1688中国站按关键字搜索工厂数据 API
公共参数 名称类型必须描述keyString是申请免费调用key(必须以GET方式拼接在URL中)secretString是调用密钥api_nameString是API接口名称(包括在请求地址中)[item_search,item_get,item_search_shop等]cacheString否[yes,no]默认y…...
YOLOV8逐步分解(2)_DetectionTrainer类初始化过程
接上篇文章yolov8逐步分解(1)--默认参数&超参配置文件加载继续讲解。 1. 默认配置文件加载完成后,创建对象trainer时,需要从默认配置中获取类DetectionTrainer初始化所需的参数args,如下所示 def train(cfgDEFAULT_CFG, use_pythonFalse…...
Java是用什么语言写的?PHP呢?
Java底层是C语言。 Sun公司研发人员根据嵌入式软件的要求,对C进行了改造,去除了留在C的一些不太实用及影响安全的成分,并结合嵌入式系统的实时性要求,开发了一种称为Oak的面向对象语言。而后,经过迭代更新,…...
SpringBoot Redis的使用
官方文档: 官方文档:Spring Data Redis :: Spring Data Redis 和jedis一样,SpringBoot Redis 也可以让我在Java代码中使用redis,同样也是通过引入maven依赖的形式。 加速访问github: 使用steam可以免费加速访问github Spring…...
数据仓库——维度表特性
企业信息化工厂 数据集市中的一致性,由于企业信息化工厂的数据集市是从集成仓库中获得信息的,因此至少从维度建模的角度来看,一致性维护的问题减少了。尽管合并不同数据源的问题依然在,但是负担主要在设计者身上。尽管压力降低了…...
从电荷角度理解开关电容中的电荷守恒
目录 一些铺垫电容的电荷量的解释电荷流入流出对节点电压的影响 从电荷角度理解开关电容加法器中的电荷守恒以开关电容积分器为例说明什么样的节点是电荷守恒 一些铺垫 电容的电荷量的解释 对于一个1F的电容,当它的压差为1V时,它所携带的电荷量是QCU1库…...
1.7.1 python 作业 15道
1、求出1 / 1 1 / 3 1 / 5……1 / 99的和 (1分之一1分之三1分支5....) sum0 for i in range(1,100,2): sum 1/i sum; print(sum) 2、用循环语句,计算2 - 10之间整数的循环相乘的值 (2*3*4*5....10) sum 1 for i in range(2,11): sum sum *…...
synchronized 和 ReentrantLock 的区别是什么
该文章专注于面试,面试只要回答关键点即可,不需要对框架有非常深入的回答,如果你想应付面试,是足够了,抓住关键点 面试官:synchronized 和 ReentrantLock 的区别是什么 1. 获取锁的方式 synchronized:synchronized的锁获取是隐式的。当线程进入synchronized修饰的代码…...
大话设计模式之迪米特法则
迪米特法则,也称为最少知识原则(Law of Demeter),是面向对象设计中的一个重要原则,其核心思想是降低耦合度、减少对象之间的依赖关系,从而使系统更加灵活、易于维护和扩展。 根据迪米特法则,一…...
KSD测试系统使用方法和注意事项
①下载链接在最顶部; ②安装方法:应该先将测试设备绑定在假人身上,测试设备不能过度往下拉,传感器绑在脖子上,切记最后才开传感器开关!!!开传感器后3秒内不要碰测试设备衣服&#x…...
IT服务营销管理案例分析题
习题一 企业随着业务的蓬勃发展,所投入的基础设施资源不断增加。企业员工数倍数增长,办公场地、办公环境等要求也越来越高。 可是该企业的IT部门人员短缺,对IT管理还处于被动的“救火”阶段,每天至少15个突发故障,故障…...
NRF52832修改OTA升级时的bootloader蓝牙MAC
NRF52832在OTA升级时,修改了APP的蓝牙MAC会导致无法升级,原因是OTA程序的蓝牙MAC没有被修改所以手机扫描蓝牙时无法连接 解决办法 在bootloader的程序里面加入修改蓝牙mac地址的代码实现原理: 在bootloader蓝牙广播开启之前修改蓝牙mac 通…...
# Python 编程入门教程
欢迎来到 Python 编程入门教程!Python 是一种简单易学、功能强大的编程语言,适用于各种应用场景,从简单的脚本到大型软件开发项目。无论你是初学者还是有一定编程经验的开发者,本教程都将为你提供全面的学习路径,帮助你掌握 Python 编程的基础知识和技能。 ## 目录 1. 简…...
Sqoop【实践 02】Sqoop1最新版 全库导入 + 数据过滤 + 字段类型支持 说明及举例代码(query参数及字段类型强制转换)
Sqoop1最新版举例 1.环境说明2.import-all-tables3.query4.字段类型支持 1.环境说明 还是之前的环境: # 不必要信息不再贴出 # JDK [roottcloud ~]# java -version java version "1.8.0_251" # MySQL [roottcloud ~]# mysql -V mysql Ver 14.14 Distrib…...
第十四届蓝桥杯JavaA组省赛真题 - 特殊日期
解题思路: 暴力秒了 public class Main {public static void main(String[] args) {int cnt 0;for (int i 1900; i < 9999; i) {for (int j 1; j < 12; j) {for (int k 1; k < days(i, j); k) {if (sum(i) sum(j) sum(k)) cnt;}}}System.out.print…...
《VulnHub》Lampião:1
title: 《VulnHub》Lampio:1 date: 2024-03-28 21:37:49 updated: 2024-03-28 21:37:50 categories: WriteUp:Cyber-Range excerpt: 关键技术:主机发现,端口扫描、服务探测、操作系统探测,对开放的端口探测漏洞&#x…...
RabbitMq高可用
消息队列高级 服务异步通信-高级篇1.消息可靠性1.1.生产者消息确认1.2.消息持久化1.3.消费者消息确认1.4.消费失败重试机制1.5.总结 2.死信交换机2.1.初识死信交换机2.2.TTL2.3.延迟队列 3.惰性队列3.1.消息堆积问题3.2.惰性队列 4.MQ集群4.1.集群分类4.2.普通集群4.3.镜像集群…...
降本增效的车间管理大屏,车间主任看了拍手称快,速来领取。
我们老板觉得车间生产效率太低了,还想让我整一套车间管理的! 制造业管理的核心在于降本增效,车间管理可以通过【大数据可视化】来提高管理效率,大屏就可以做到生产管理一「屏」了然,这是【车间管理大屏方案】。 一、…...
Open AI要给GPT应用开发者“发钱” 黄金的宏观关系被打破了吗?
内容摘要 为避免GPTs彻底凉凉,Open AI紧急启动了一项“货币化”计划,直接给那些在GPT Store上的应用开发人员发钱。 正文部分 当地时间周四凌晨,OpenAI在社交媒体上发帖称,正在与小部分美国开发者合作,基于用户使用…...
AI安全评估:从黑盒到白盒的深度实践
1. 项目概述:AI安全评估的现状与挑战在人工智能技术快速发展的今天,大型语言模型(LLM)和多模态模型(MLLM)的安全性问题已成为行业关注的焦点。随着模型能力的不断提升,其潜在风险也呈现出复杂化…...
【困难】用栈来求解汉诺塔问题-Java:解法一
分享一个大牛的人工智能教程。零基础!通俗易懂!风趣幽默!希望你也加入到人工智能的队伍中来!请轻击人工智能教程大家好!欢迎来到我的网站! 人工智能被认为是一种拯救世界、终结世界的技术。毋庸置疑&#x…...
(复现)基于反演滑模控制器+自适应算法+非线性干扰观测器算法的机械臂抖振消除、抗干扰、强鲁棒Simulink仿真(Matlab代码、Simulink仿真实现)
💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…...
自主编码框架解析:从AI编程助手到闭环开发系统
1. 项目概述:一个面向自主编码的智能开发框架最近在开源社区里,一个名为GantisStorm/autonomous-coding-harness的项目引起了我的注意。乍一看这个标题,它像是一个工具集或框架,核心关键词是“自主编码”。对于开发者而言…...
CnOpenData 税收调查企业发明专利授权质量统计表
税收是支撑国家长期发展的根本基础。作为服务财税改革、加强财税管理的一项重要基础性工作,全国税收调查工作为税收政策制定提供了扎实的数据支撑;同时,它对于学者准确掌握税源情况、窥探经济发展形势起到重要作用。参与全国税收调查的企业分…...
基于MITRE ATTCK的AI代理安全评估框架与实践
1. 计算机使用代理安全评估框架解析在当今企业IT环境中,计算机使用代理(Computer-Using Agents, CUAs)作为AI代理技术的重要实现形式,正逐渐渗透到系统管理、自动化运维等关键领域。然而,这些具备自主决策能力的代理程序,其安全性…...
JavaScript窗口大小调整resize事件的适配方案
应节流控制并精准判断尺寸变化:设定100–250ms时间阈值限制resize触发频率,缓存并比对window.innerWidth/innerHeight避免无意义执行;局部变化优先用ResizeObserver;组件卸载时务必清除监听器防内存泄漏。监听窗口大小变化时&…...
CALM框架:连续向量空间语言建模技术解析
1. CALM框架概述:连续向量空间的语言建模革命在传统语言模型(LM)领域,自回归式逐标记(token-by-token)生成已成为标准范式。这种方法的计算效率受限于序列长度,生成长文本时需要执行数百甚至上千次前向传播。CALM(Continuous Autoregressive …...
5分钟搞定!魔兽争霸III WarcraftHelper插件完全指南:解锁300帧+宽屏完美体验
5分钟搞定!魔兽争霸III WarcraftHelper插件完全指南:解锁300帧宽屏完美体验 【免费下载链接】WarcraftHelper Warcraft III Helper , support 1.20e, 1.24e, 1.26a, 1.27a, 1.27b 项目地址: https://gitcode.com/gh_mirrors/wa/WarcraftHelper 还…...
Awesome Codex Skills中的Basin自动化:表单处理和数据收集的终极工具
Awesome Codex Skills中的Basin自动化:表单处理和数据收集的终极工具 【免费下载链接】awesome-codex-skills A curated list of practical Codex skills for automating workflows across the Codex CLI and API. 项目地址: https://gitcode.com/GitHub_Trending…...
