Collections的sorts方法
List list1=Arrays.asList(3,2,1); Collections.sort(list1); List list2=Arrays.asList("abcd","sdf","sss"); Collections.sort(list2);
上面两行代码,都可以正确的以asc方式排序。
然而,如果新建一个对象呢?看起来似乎可以。
Student.java代码:
public class Student { private int age; private String name; private Sex sex; public Student(int age,String name,Sex sex){ this.age=age; this.name=name; this.sex=sex; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } public String getName() { return name; } public void setName(String name) { this.name = name; } public Sex getSex() { return sex; } public void setSex(Sex sex) { this.sex = sex; } }
在main方法里:
List<Student> studentList = Arrays.asList(student1,student2,student3);
Collections.sort(studentList);
这里会报错:
如图,显示Student对象不符合泛型T的范围,而正如提示里,在sorts方法里,T是extends Compareable<? super T>的,所以T泛型的对象必须是实现了Compareable接口的,才刻意排序。
那么这种情况下,我们就需要用sorts的自定义排序方法的方法。
List<Student> studentList = Arrays.asList(student1,student2,student3); Collections.sort(studentList,(a,b)->{ //比如按照姓名的升序排列 return a.getName().compareTo(b.getName()); });
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!