list.sort()&&Collections.sort()深入理解

list.sort()&&Collections.sort()

文章目录

背景

业务中经常用到List的sort()方法,但是对于其中return的-1,0,1理解不到位,导致业务出现错误;

网上对于-1,0,1的表述并不是很清楚,今天详细聊一聊。

相关代码

先分享两段代码

业务逻辑:通过student类中的属性level做比较,level数字较小的排在前面

代码一

java 复制代码
studentList.sort((o1, o2) -> {
			if (o1.getstudentLevel() < o2.getstudentLevel()) {
				return -1;
			} else if (o1.getstudentLevel() > o2.getstudentLevel()) {
				return 1;
			} else {
				return 0;
			}
		});

代码二

java 复制代码
Collections.sort(studentList, new Comparator<Student>() {
			@Override
			public int compare(Student o1, Student o2) {
				if (null == o1 && null == o2) {
					return 0;
				}
				if (null == o1) {
					return 1;
				}
				if (null == o2) {
					return -1;
				}
				Long studentLevel1 = o1.getStudentLevel();
				Long studentLevel2 = o2.getStudentLevel();
				if (Objects.isNull(studentLevel1) && Objects.isNull(studentLevel2)) {
					return 0;
				}
				if (Objects.isNull(studentLevel1)) {
					return 1;
				}
				if (Objects.isNull(studentLevel2)) {
					return -1;
				}
				return studentLevel1.compareTo(studentLevel2);
			}
		});

原理

  • 要解释-1,0,1的含义,首先需要看o1,o2的顺序,也就是sort方法后括号中的内容,我们暂定为参数1和参数2,如图

    代码二的参数同图中一样,看明白这张图就可以解释-1,0,1的意思了

    -1:代表参数一 排前面

    0:位置不变

    1:代表参数二 排前面

    也就是说排序的顺序和写的参数顺序有关系,代码一中就可以理解为:-1代表o1排前面,1代表o2排前面;

  • 再来解释一下if中的条件和返回值的关系

    其实if中的条件可以理解为场景,也就是在什么场景下,参数一排在前面,什么场景下参数二排在前面;

  • 综上,这段代码就可以这样理解了:

    当o1的studentLevel小于o2的studentLevel值时,o1排在前面;

    当o1的studentLevel大于o2的studentLevel值时,o2排在前面;

    其他情况,也就是等于时,位置不变。

  • 对于代码二中的语句

java 复制代码
if (Objects.isNull(studentLevel2)) {
	return -1;
}

可以理解为当studentLevel2为空的时候,o1排在前面,即studentLevel1排在前面,这句话的意思也就是为null的排在后面。

这个逻辑确实很难理解,外国人的思维感觉很奇妙。

举一反三

很难理解,再来个代码理解一下

java 复制代码
studentList.sort((o2, o1) -> {
			if (o1.getstudentLevel() < o2.getstudentLevel()) {
				return 1;
			} else if (o1.getstudentLevel() > o2.getstudentLevel()) {
				return -1;
			} else {
				return 0;
			}
		});

可以思考一下这段代码是什么意思,大家可以评论起来。

业务场景考虑

讲完原理,再说一下业务上的问题,对于业务,我最开始用的是代码一的写法,但是codeReview时就发现了问题。

  • 问题一:当list中的对象为空时,排序会出现错误
  • 问题二:当对象中的属性studentLevel为空时,排序会出现错误

所以针对这两个问题对代码进行了优化,就有了代码二的写法,这种写法相当于是重写了compare方法,将null的情况考虑进去,这样的排序就成了不为空的时候,按照level从小到大排序,为空的排在不为空的后面。

当然还有其他优化方法,比如先将不为null的筛选出来排序,再将为null的拼接到后面,这里就不提供代码了。

相关推荐
低保和光头哪个先来1 分钟前
场景6:对浏览器内核的理解
开发语言·前端·javascript·vue.js·前端框架
小北方城市网4 分钟前
Python + 前后端全栈进阶课程(共 10 节|完整版递进式|从技术深化→项目落地→就业进阶,无缝衔接基础课)
大数据·开发语言·网络·python·数据库架构
程序员JerrySUN9 分钟前
OP-TEE + YOLOv8:从“加密权重”到“内存中解密并推理”的完整实战记录
android·java·开发语言·redis·yolo·架构
阿里嘎多学长20 分钟前
2025-12-30 GitHub 热点项目精选
开发语言·程序员·github·代码托管
+VX:Fegn089528 分钟前
计算机毕业设计|基于springboot + vueOA工程项目管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·课程设计
郝学胜-神的一滴37 分钟前
Linux进程与线程控制原语对比:双刃出鞘,各显锋芒
linux·服务器·开发语言·数据结构·c++·程序人生
JasmineWr41 分钟前
Spring事务解析
java·spring
wang60212521842 分钟前
阿里云存储的下载验证
数据库·阿里云·fastapi
小钟不想敲代码44 分钟前
Python(一)
开发语言·python
ji_shuke1 小时前
canvas绘制拖拽箭头
开发语言·javascript·ecmascript