userList.stream().sorted((u1, u2) -> u2.getAge() - u1.getAge()); 怎么判断是升序还是降序?

一、先看你这句代码

java

运行

scss 复制代码
sorted((u1, u2) -> u2.getAge() - u1.getAge());

一眼判定:年龄降序(大的在前,小的在后)

二、底层原理:Comparator 比较规则(核心)

sorted() 里面的 Lambda 就是 Comparator.compare(o1,o2)格式固定:

java

运行

rust 复制代码
(o1, o2) -> 【返回值】

返回值规则只有三句,背这三句就够

  1. 返回负数o1 排在 o2 前面
  2. 返回 0:两者位置不变
  3. 返回正数o1 排在 o2 后面

三、最简单万能口诀(必背)

口诀 1:减法版数字排序

java

运行

rust 复制代码
(o1, o2) -> o1 - o2

o1 - o2 = 升序(从小到大)


java

运行

rust 复制代码
(o1, o2) -> o2 - o1

o2 - o1 = 降序(从大到小)

结论:前面减后面 = 升序 后面减前面 = 降序

四、套到你的 User 年龄上拆解

你的代码:

java

运行

scss 复制代码
(u1, u2) -> u2.getAge() - u1.getAge()
  • u1:第一个对象
  • u2:第二个对象
  • 年龄:u2年龄 - u1年龄

属于 后面减前面降序

举个例子:u1 年龄 = 20,u2 年龄 = 25

java

运行

ini 复制代码
25 - 20 = 正数

返回正数 → 根据规则:o1 排在后面 也就是 25 在前,20 在后 → 大的在前 = 降序

五、全部对比一眼看懂

1)年龄升序(从小到大)

java

运行

scss 复制代码
sorted((u1, u2) -> u1.getAge() - u2.getAge());

前 - 后 = 升序

2)年龄降序(从大到小)

java

运行

scss 复制代码
sorted((u1, u2) -> u2.getAge() - u1.getAge());

后 - 前 = 降序

六、最通俗大白话解释(完全不用记原理)

  1. **u1 - u2**你自己减自己后面的 → 从小到大 升序
  2. **u2 - u1**后面的减你自己 → 从大到小 降序

七、再给你扩展到字符串、通用写法

不光数字年龄,所有都适用:

1、升序(字母从小到大)

java

运行

scss 复制代码
sorted((s1,s2)->s1.compareTo(s2))

2、降序(字母从大到小)

java

运行

scss 复制代码
sorted((s1,s2)->s2.compareTo(s1))

八、终极总结(你以后直接套用)

  1. o1 - o2 = 升序
  2. o2 - o1 = 降序
  3. 只要看到后面参数减前面参数 ,一律降序
  4. 只要看到前面减后面 ,一律升序
相关推荐
NE_STOP11 小时前
Vibe Coding -- 完整项目案例实操
java
荣码11 小时前
GraphRAG:普通RAG只能回答"点"的问题,我踩了4个坑才搞懂
java·python
SimonKing11 小时前
Google第三方授权登录
java·后端·程序员
明月光81811 小时前
从一行 @Builder 说起:重新拾起 Java 的 Lombok、注解与 Builder 模式
java
考虑考虑20 小时前
Mybatis实现批量插入
java·后端·mybatis
咖啡八杯21 小时前
GoF设计模式——中介者模式
java·后端·spring·设计模式
青石路1 天前
记一次多JDK版本问题的排查,一坑套一坑,差点没爬上来
java
像我这样帅的人丶你还1 天前
Java 后端详解(五):Redis 缓存
java·后端·全栈
plainGeekDev1 天前
GreenDAO → Room
android·java·kotlin
亦暖筑序1 天前
Java 8老系统AI Workflow实战:把一次性AI对话升级成可恢复工作流
java·后端