当前位置: 首页 > article >正文

List对象进行排序

目录

一、List对象中某个值进行排序

代码示例

注意事项

二、List.sort  和 Collections.sort 异同

1. 方法所属

2. 使用方式

3. 是否修改原列表

4. 泛型支持

5. 性能

6. 适用场景

7. 示例代码对比

使用 testList.sort

 使用 Collections.sort

8. 总结

 三、为对象多个属性进行排序

示例代码


一、List对象中某个值进行排序

用空间换时间,Java在内存中进行对象集合排序。

在 Java 中,可以使用 Listsort 方法或者 Collections.sort 方法,结合自定义的比较器(Comparator),对 List<Test> 按照 LocalDate 类型的字段 startTime 进行排序。

代码示例

import java.time.LocalDate;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;class Test {private String name;private LocalDate startTime;// 构造函数public Test(String name, LocalDate startTime) {this.name = name;this.startTime = startTime;}// Getter 和 Setterpublic LocalDate getStartTime() {return startTime;}@Overridepublic String toString() {return "Test{name='" + name + "', startTime=" + startTime + "}";}
}public class SortExample {public static void main(String[] args) {// 创建一个 Test 对象列表List<Test> testList = new ArrayList<>();testList.add(new Test("Test1", LocalDate.of(2023, 3, 15)));testList.add(new Test("Test2", LocalDate.of(2023, 1, 10)));testList.add(new Test("Test3", LocalDate.of(2023, 2, 20)));// 使用 Comparator 对 startTime 字段进行排序testList.sort(Comparator.comparing(Test::getStartTime));// 或者使用 Collections.sort 方法// Collections.sort(testList, Comparator.comparing(Test::getStartTime));// 输出排序后的结果testList.forEach(System.out::println);}
}

如果需要按降序排序,可以在 Comparator 上调用 reversed() 方法:

testList.sort(Comparator.comparing(Test::getStartTime).reversed());

注意事项

  1. 空值处理

    testList.sort(Comparator.comparing(Test::getStartTime, Comparator.nullsLast(Comparator.naturalOrder())));
  2. 线程安全List.sort 方法会直接修改原列表的内容。如果需要保留原始列表不变,可以先复制一份再排序。

  3. Java 版本:以上代码适用于 Java 8 及更高版本,因为 LocalDateComparator.comparing 是 Java 8 引入的功能。

二、List.sort  和 Collections.sort 异同

1. 方法所属

  • testList.sort

    • List 接口中的一个方法(从 Java 8 开始引入)。

    • 直接作用于 List 对象本身。

  • Collections.sort

    • java.util.Collections 工具类中的一个静态方法。

    • 专门用于对 List 类型的集合进行排序。

2. 使用方式

  • testList.sort

    testList.sort(Comparator.comparing(Test::getStartTime));
    • 调用的是 List 的实例方法,直接在 List 上调用。

  • Collections.sort

Collections.sort(testList, Comparator.comparing(Test::getStartTime));
  • 调用的是 Collections 的静态方法,需要显式传入 List 参数。

3. 是否修改原列表

  • testList.sort

    • 直接修改原列表的内容。

  • Collections.sort

    • 同样会直接修改原列表的内容。

4. 泛型支持

  • testList.sort

    • 支持 Lambda 表达式和方法引用(Java 8+),代码更简洁。

  • Collections.sort

    • 同样支持 Lambda 表达式和方法引用,但在语法上稍微冗长一些。

5. 性能

  • testList.sortCollections.sort

    • 两者底层实现相同,均使用 Timsort 算法(一种基于归并排序的稳定排序算法),时间复杂度为 O(n log n)。

    • 因此,在性能上没有明显差异。

6. 适用场景

  • testList.sort

    • 更适合现代 Java 开发(Java 8+),代码更简洁直观。

  • Collections.sort

    • 在 Java 8 之前,这是唯一的排序方式。

    • 如果需要对非 List 类型的集合进行排序(例如 ArrayList 的父接口 List),仍然可以使用 Collections.sort

7. 示例代码对比

使用 testList.sort
import java.util.ArrayList;
import java.util.Comparator;
import java.util.List;public class TestSort {public static void main(String[] args) {List<String> list = new ArrayList<>();list.add("C");list.add("A");list.add("B");// 使用 testList.sort 方法list.sort(Comparator.naturalOrder());System.out.println(list); // 输出: [A, B, C]}
}
 使用 Collections.sort
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;public class TestSort {public static void main(String[] args) {List<String> list = new ArrayList<>();list.add("C");list.add("A");list.add("B");// 使用 Collections.sort 方法Collections.sort(list, Comparator.naturalOrder());System.out.println(list); // 输出: [A, B, C]}
}

8. 总结

特性

testList.sort

Collections.sort

所属

List 接口的方法

Collections 工具类的静态方法

调用方式

直接调用 List 实例方法

需要显式传入 List 参数

是否修改原列表

泛型支持

支持 Lambda 和方法引用

支持 Lambda 和方法引用

性能

相同(Timsort 算法)

相同(Timsort 算法)

适用场景

Java 8+ 推荐使用

Java 8 之前的唯一选择

 三、为对象多个属性进行排序

示例代码
import java.time.LocalDate;
import java.util.ArrayList;
import java.util.Comparator;
import java.util.List;class Test {private String name;private LocalDate startTime;private int score;// 构造函数public Test(String name, LocalDate startTime, int score) {this.name = name;this.startTime = startTime;this.score = score;}// Getter 方法public String getName() {return name;}public LocalDate getStartTime() {return startTime;}public int getScore() {return score;}@Overridepublic String toString() {return "Test{name='" + name + "', startTime=" + startTime + ", score=" + score + "}";}
}public class MultiFieldSortExample {public static void main(String[] args) {// 创建一个 Test 对象列表List<Test> testList = new ArrayList<>();testList.add(new Test("Alice", LocalDate.of(2023, 1, 15), 80));testList.add(new Test("Bob", LocalDate.of(2023, 1, 10), 90));testList.add(new Test("Charlie", LocalDate.of(2023, 1, 10), 90));testList.add(new Test("David", LocalDate.of(2023, 1, 15), 70));testList.add(new Test("Eve", LocalDate.of(2023, 1, 10), 85));// 按多个字段排序testList.sort(Comparator.comparing(Test::getStartTime) // 按 startTime 升序.thenComparing(test -> -test.getScore()) // 按 score 降序(负号实现).thenComparing(Test::getName)); // 按 name 升序// 输出排序后的结果testList.forEach(System.out::println);}
}

相关文章:

List对象进行排序

目录 一、List对象中某个值进行排序 代码示例 注意事项 二、List.sort 和 Collections.sort 异同 1. 方法所属 2. 使用方式 3. 是否修改原列表 4. 泛型支持 5. 性能 6. 适用场景 7. 示例代码对比 使用 testList.sort 使用 Collections.sort 8. 总结 三、为对象多…...

Java 设计模式之备忘录模式

文章目录 Java 设计模式之备忘录模式概述UML代码实现 Java 设计模式之备忘录模式 概述 备忘录(Memento)&#xff1a;在不破坏封装性的前提下&#xff0c;捕获一个对象的内部状态&#xff0c;并在该对象之外保存这个状态。方便对该对象恢复到原先保存的状态。 UML Originnato…...

vue3搭建实战项目笔记二

vue3搭建实战项目笔记二 2.1.git管理项目2.2.隐藏tabBar栏2.2.1 方案一&#xff1a;在路由元信息中设置一个参数是否显示tabBar2.2.2 方案二&#xff1a;通过全局设置相对定位样式 2.3.项目里封装axios2.3.1 发送网络请求的两种做法2.3.2 封装axios并发送网络请求2.3.2.1 对axi…...

【原创】解决vue-element-plus-admin无法实现下拉框动态控制表单功能,动态显隐输入框

前言 目前使用vue-element-plus-admin想要做一个系统定时任务功能&#xff0c;可以选择不同的定时任务类型&#xff0c;比如使用cron表达式、周期执行、指定时间执行等。每种类型对应不同的输入框&#xff0c;需要动态显隐输入框才行&#xff0c;但是这个vue-element-plus-adm…...

大疆无人机需要的kml文件如何制作kml导出(大疆KML文件)

大疆无人机需要的轨迹kml文件&#xff0c;是一种专门的格式&#xff0c;这个kml里面只有轨迹点&#xff0c;其它的属性信息都不需要。 BigemapPro提供了专门的大疆格式输出&#xff0c; 软件这里下载 www.bigemap.com 安装后&#xff0c;kml导入如下图&#xff1a; 然后选择…...

前端知识速记--css篇:CSS3中的常见动画及实现方式

前端知识速记–css篇&#xff1a;CSS3中的常见动画及实现方式 常见的CSS3动画 1. 过渡 (Transitions) 过渡是一种非常简单的动画效果&#xff0c;允许你在元素的状态变更时平滑过渡到新状态。 语法格式&#xff1a; transition: property duration timing-function delay;…...

YOLOV8的学习记录(二) yolo8的几个内置模型简介

YOLOv8 是一个多功能的计算机视觉框架&#xff0c;支持多种任务&#xff0c;包括分类&#xff08;Classify&#xff09;、检测&#xff08;Detect&#xff09;、旋转目标检测&#xff08;OBB&#xff09;、姿态估计&#xff08;Pose&#xff09;、实例分割&#xff08;Segment&…...

免费deepseek的API获取教程及将API接入word或WPS中

免费deepseek的API获取教程: 1 https://cloud.siliconflow.cn/中注册时填写邀请码&#xff1a;GAejkK6X即可获取2000 万 Tokens; 2 按照图中步骤进行操作 将API接入word或WPS中 1 打开一个word&#xff0c;文件-选项-自定义功能区-勾选开发工具-左侧的信任中心-信任中心设置…...

Windows操作系统部署Tomcat详细讲解

Tomcat是一个开源的Java Servlet容器&#xff0c;用于处理Java Web应用程序的请求和响应。以下是关于Tomcat的用法大全&#xff1a; 一、安装Tomcat 下载 访问Apache Tomcat官方网站&#xff08;https://tomcat.apache.org/&#xff09;&#xff0c;根据你的操作系统&#xf…...

深入解析A2DP v1.4协议:蓝牙高质量音频传输的技术与实现

1. A2DP概述 A2DP&#xff08;Advanced Audio Distribution Profile&#xff09;是一种高质量音频流媒体协议&#xff0c;旨在实现高质量音频内容的分发&#xff0c;通常用于通过蓝牙设备传输音频数据&#xff0c;例如将音乐从便携式播放器传输到耳机或扬声器。与传统的蓝牙语…...

(三)Axure制作转动的唱片

效果图 属性&#xff1a; 图标库&#xff1a;iconfont-阿里巴巴矢量图标库 方形图片转为圆角图片&#xff0c;裁剪&#xff0c;然后加圆角&#xff0c; 唱片和底图是两个图片&#xff0c;点击播放&#xff0c;唱片在旋转。 主要是播放按钮和停止按钮&#xff0c;两个动态面板…...

VueRouter 实例

分析下列代码 const router new VueRouter({mode:history,routes }) 1.const router new VueRouter({ ... })用来创建一个 Vue Router 实例&#xff0c;用于管理 Vue.js 应用的路由。2.mode: history&#xff1a; 作用&#xff1a;启用 HTML5 History 模式&#xff0c;去除…...

Docker 镜像标签使用

写在前面 当使用命令 docker pull mysql 拉取镜像时&#xff0c;其实等价于如下命令 docker pull mysql:latest latest 是默认的标签&#xff0c;字面上理解为最新版本的镜像&#xff0c;实质上 latest 只是镜像的标签名称&#xff0c;跟具体某个版本号地位一样&#xff0c;…...

ASP.NET Core SixLabors.ImageSharp 位图图像创建和下载

从 MVC 控制器内部创建位图图像并将其发送到浏览器&#xff1b;用 C# 编写并与 Linux 和 Windows 服务器兼容。 使用从 ASP.NET MVC 中的控制器下载任何文件类型File。 此示例创建一个位图 (jpeg) 并将其发送到浏览器。它需要 NuGet 包SixLabors.ImageSharp v1.0.4。 另请参…...

蓝桥杯篇---超声波距离测量频率测量

文章目录 简介第一部分&#xff1a;超声波的简介工作原理1.发射超声波2.接收反射波3.计算时间差4.计算距离 硬件连接1.Trig2.Echo 示例代码代码说明注意事项1.声速2.延时精度3.硬件连接 第二部分&#xff1a;频率测量简介频率测量原理1.信号输入2.计数3.计算频率 硬件连接示例代…...

机器学习所需要的数学知识【01】

总览 导数 行列式 偏导数 概理论 凸优化-梯度下降 kkt条件...

【D2】神经网络初步学习

总结&#xff1a;学习了 PyTorch 中的基本概念和常用功能&#xff0c;张量&#xff08;Tensor&#xff09;的操作、自动微分&#xff08;Autograd&#xff09;、正向传播、反向传播。通过了解认识LeNet 模型&#xff0c;定义神经网络类&#xff0c;熟悉卷积神经网络的基本结构和…...

变相提高大模型上下文长度-RAG文档压缩-3.优化map-reduce(reranker过滤+社区聚类)

我遇到的业务问题实际上是RAG需要处理很多同一对象的日常报告&#xff0c;不像常识类问题&#xff0c;它的相关Document更多而且更分散&#xff0c;日常报告代表数据库里有很多它的内容&#xff0c;而且对象可能只在段落中的几句话提及到。top-k数量受限于大模型长度&#xff0…...

电解电容的参数指标

容量 这个值通常是室温25℃&#xff0c;在一定频率和幅度的交流信号下测得的容量。容量会随着温度、直流电压、交流电压值的变化而改变。 额定电压 施加在电容上的最大直流电压&#xff0c;通常要求降额使用。 例如额定电压是4V&#xff0c;降额到70%使用&#xff0c;最高施…...

计时器任务实现(保存视频和图像)

下面是一个简单的计时器任务实现&#xff0c;可持续地每秒保存一幅图像&#xff0c;也可持续地每60秒保存一个视频&#xff0c;图像和视频均以当前时间命名&#xff1a; TimerTask类的实现如下&#xff1a; class TimerTask { public:TimerTask(const std::string& path):…...

Django 美化使用ModelForm的输入框

在初次使用ModelForm时&#xff0c;我的html文件代码如下&#xff0c;主要内容是显示一个卡片式表单&#xff0c;通过循环遍历 form 对象动态生成表单字段 {% extends layout.html %}{% block content %} <div class"container"><div class"c1"&g…...

应用层优秀的共享民宿物联网框架该怎么选?

有一说一&#xff0c;应用层优秀的物联网框架通常能帮助提升用户体验、提高运营效率、节能减排等等优势&#xff0c;很多老板也很注重这个层面的设计和打磨&#xff0c;那么对于选择应用层优秀的共享民宿物联网框架时&#xff0c;大家可以从哪几个关键因素进行考量呢&#xff1…...

【kafka系列】生产者

目录 发送流程 1. 流程逻辑分析 阶段一&#xff1a;主线程处理 阶段二&#xff1a;Sender 线程异步发送 核心设计思想 2. 流程 关键点总结 重要参数 一、核心必填参数 二、可靠性相关参数 三、性能优化参数 四、高级配置 五、安全性配置&#xff08;可选&#xff0…...

HCIA-路由器相关知识和面试问题

二、 路由器 2.1 关于路由器的知识 2.1.1 什么是路由器 路由器是一种网络层互联设备&#xff0c;主要用于连接多个逻辑上分开的网络&#xff0c;实现不同网络之间的数据路由和通信。它能根据网络层地址&#xff08;如 IP 地址&#xff09;来转发数据包&#xff0c;在网络中起…...

Unity 获取独立显卡数量

获取独立显卡数量 导入插件包打开Demo 运行看控制台日志 public class GetGraphicCountDemo : MonoBehaviour{public int count;// Start is called before the first frame updatevoid Start(){count this.GetIndependentGraphicsDeviceCount();}}...

【stm32】定时器输出PWM波形(hal库)

一. PWM基本原理 PWM是一种通过调节信号的占空比&#xff08;Duty Cycle&#xff09;来控制输出平均电压的技术。占空比是指高电平时间与整个周期时间的比值。例如&#xff1a; - 占空比为50%时&#xff0c;输出平均电压为电源电压的一半。 - 占空比为100%时&#xff0c;输出始…...

Deepseek R1模型本地化部署+API接口调用详细教程:释放AI生产力

文章目录 前言一、deepseek R1模型与chatGPT o1系列模型对比二、本地部署步骤1.安装ollama2部署DeepSeek R1模型删除已存在模型&#xff0c;以7b模型为例 三、DeepSeek API接口调用Cline配置 前言 随着最近人工智能 DeepSeek 的爆火&#xff0c;越来越多的技术大佬们开始关注如…...

Mac ARM 架构的命令行(终端)中,删除整行的快捷键是:Ctrl + U

在 Mac ARM 架构的命令行&#xff08;终端&#xff09;中&#xff0c;删除整行的快捷键是&#xff1a; Ctrl U这个快捷键会删除光标所在位置到行首之间的所有内容。如果你想删除光标后面的所有内容&#xff0c;可以使用&#xff1a; Ctrl K这两个快捷键可以帮助你快速清除当…...

用pytorch实现一个简单的图片预测类别

前言&#xff1a; 在阅读本文之前&#xff0c;你需要了解Python&#xff0c;Pytorch&#xff0c;神经网络的一些基础知识&#xff0c;比如什么是数据集&#xff0c;什么是张量&#xff0c;什么是神经网络&#xff0c;如何简单使用tensorboard,DataLoader。 本次模型训练使用的是…...

深度学习框架探秘|TensorFlow:AI 世界的万能钥匙

在人工智能&#xff08;AI&#xff09;蓬勃发展的时代&#xff0c;各种强大的工具和框架如雨后春笋般涌现&#xff0c;而 TensorFlow 无疑是其中最耀眼的明星之一。它不仅被广泛应用于学术界的前沿研究&#xff0c;更是工业界实现 AI 落地的关键技术。今天&#xff0c;就让我们…...