list排序
public static void main(String[] args) { List<String> list = new ArrayList<String>(); list.add("a"); list.add("e"); list.add("b"); list.add("c"); list.add("d"); list.sort((a,b)->a.compareTo(b));//[a, b, c, d, e] list.sort((a,b)->b.compareTo(a));//[e, d, c, b, a] System.out.println(list); }
Comparator接口
位于java.util 包下接口 Comparator< T > 其中 T为需要比较的参数,可以将 Comparator 传递给 sort 方法,从而允许在排序顺序上实现精确控制
方法为
int compare(T o1, T o2) , 比较用来排序的两个参数。
boolean equals(Object obj) 指示某个其他对象是否“等于”此 Comparator。
在使用中参数为此接口的方法有(常用):
例如对于compare(T o1, T o2)方法:
在对接口进行实现时可以调用此方法,比较用来排序的两个参数。根据第一个参数小于、等于或大于第二个参数分别返回负整数、零或正整数,
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 | import java.util.Arrays; import java.util.Comparator; public class Demo01_Arrays { public static void main(String[] args) { Person[] arr = { new Person( "柳岩" , 15 ), new Person( "迪丽热巴" , 16 ), new Person( "马尔扎哈" , 18 ), new Person( "古力娜扎" , 17 ), }; //对数组中的Person对象使用Arrays的sort方法,通过年龄进行升序 Arrays.sort(arr, new Comparator<Person>(){ @Override public int compare(Person o1, Person o2) { return o1.getAge()-o2.getAge(); } }); for (Person p : arr){ System.out.println(p); } //使用lambda表达式简化匿名内部类 Arrays.sort(arr, (Person o1, Person o2)->{ return o2.getAge()-o1.getAge(); }); for (Person p : arr){ System.out.println(p); } } } |
创建Person类,将四个类对象中的年龄进行排序
结果
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律