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类,将四个类对象中的年龄进行排序

结果

 

posted @   iTao0128  阅读(522)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律
点击右上角即可分享
微信分享提示