Java 比较器Comparable与Comparator的List集合排序使用

一、Collections类

    Collections则是集合类的一个工具类/帮助类,其中提供了一系列静态方法,用于对集合中元素进行排序、搜索以及线程安全等各种操作。

 用于集合排序的sort方法,此方法主要是通过ComparableComparator来实现排序。

(1) 根据其元素的natural orderinig对指定的列表进行排序

(2) 根据指定的比较器引起的顺序对指定的列表进行排序 

二、Comparable比较器

        在使用Collections的sort(List<T> list) 方法排序时,要求集合元素(对象)T必须是Comparable接口的实现类,同时重写Comparable的抽象方法 - int compareTo(T t)

 (1) 自定义对象排序:按照价格进行升序排序

public class Goods implements  Comparable<Goods> {
    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public double getPrice() {
        return price;
    }

    public void setPrice(double price) {
        this.price = price;
    }

    private String name;
    private double  price;

    //构造器、getter、setter、toString()方法略
    public Goods(String name, double price) {
        this.name = name;
        this.price = price;
    }

    public Goods() {
    }

    @Override
    public String toString() {
        return "Goods{" +
                "name='" + name + '\'' +
                ", price=" + price +
                '}';
    }

    //按照价格,比较商品的大小
    @Override
    public int compareTo(Goods o) {
        return   (int)(this.price - o.price);
    }
}

class TestGoods{
    public static void main(String[] args) {
        List<Goods> list =new ArrayList<>();
        list.add(new Goods("《红楼梦》", 100));
        list.add(new Goods("《西游记》", 88));
        list.add(new Goods("《三国演义》", 130));
        list.add(new Goods("《水浒传》", 110));
        System.out.println("排序前");
        System.out.println(list.toString());

        System.out.println("排序后");
        Collections.sort(list);
        System.out.println(list.toString());
    }
}

测试:

 Comparable优缺点

       通过案例知道,Comparable的确实现了我们想要的排序结果。但是使用Collections的sort(List<T> list) 方法排序集合时,集合元素必须实现Comparable接口并且定义比较规则。这个时候就开始出现一些问题。比如我们同一个工程使用了Goods对象,单个场景使用price进行排序,但是另一种情况下使用name排序,这个时候就出现了冲突。并且集合元素需要去实现Comparable接口,这对于我们的代码会有一些"侵入性",也不利于我们后续的代码扩展。

所以一般不建议使用,推荐使用Collections的sort(List<T> list, Comparator<? super T> c)的重载方法。

三、Comparator用法

重载sort方法:传入一个外部的比较器。
推荐使用这种方式排序集合元素,若集合元素是自定义的,创建比较器时也推荐使用匿名内部类的形式。

  (1) 自定义对象排序 + 使用List自带的排序

public class Student {
    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }

    String name;
    Integer age;

    Student(String name, Integer age) {
        this.name = name;
        this.age = age;
    }

    @Override
    public String toString() {
        return "{" +
                "name='" + name + '\'' +
                ", age=" + age +
                '}';
    }
}
class TestComparator{
    public static void main(String[] args) {
//        System.out.println(test1());
        System.out.println(test2());
    }

    /**
     * Collections.sort()测试
     * @return
     */
    private static List<Student> test1() {
        //自定义对象排序
        List<Student> students = Arrays.asList(new Student("周军",20),new Student("刘飞",18),new Student("王丽",19));

        // 使用匿名内部类进行排序
        Collections.sort(students, new Comparator<Student>() {
            @Override
            public int compare(Student o1, Student o2) {
                // 自定义排序规则
                return o1.age-o2.age;
            }
        });
        return students;
    }

    /**
     * List.sort()测试
     * @return
     */
    private static List<Student> test2() {
        //自定义对象排序
        List<Student> students = Arrays.asList(new Student("周军",20),new Student("刘飞",18),new Student("王丽",19));

        // 使用匿名内部类进行排序
      students.sort(new Comparator<Student>() {
            @Override
            public int compare(Student o1, Student o2) {
                // 自定义排序规则
                return o1.age-o2.age;
            }
        });
        return students;
    }
}

测试:

四、使用lambda简化Comparator接口

   Comparator接口是一个函数式接口,所以我们可以使用更优秀的写法,简化代码。

函数式接口就是只定义一个抽象方法的接口。
JDK1.8开始支持默认方法,即便这个接口拥有很多默认方法,只要接口只有一个抽象方法,那么这个接口就是函数式接口。

 测试:

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Java语言中可以使用以下几种方式来排序List集合: 1. 实现Comparable接口:让集合元素实现Comparable接口,并重写compareTo方法。使用Collections.sort()方法对集合排序。 2. 实现Comparator接口:使用Comparator接口的实现类来定义排序规则。使用Collections.sort(List, Comparator)方法对集合排序。 3. Java 8 Stream API:使用Stream API的sorted方法对集合排序。 4. 使用数组排序:将集合转换成数组,使用Arrays.sort()方法对数组排序,最后再将数组转换回集合。 ### 回答2: Java语言中的List集合可以使用多种方式进行排序,以下列举了几种常见的方法: 1. 使用Collections.sort()方法:通过调用Collections类的sort()方法,可以按照集合元素的自然顺序进行排序。例如: ```java List<Integer> list = new ArrayList<>(); // 添加元素到list中 Collections.sort(list); ``` 2. 使用Comparator接口:通过实现Comparator接口,可以定义自定义的排序规则。例如: ```java List<String> list = new ArrayList<>(); // 添加元素到list中 Collections.sort(list, new Comparator<String>() { @Override public int compare(String s1, String s2) { return s1.compareTo(s2); } }); ``` 3. 使用lambda表达式:Java 8及以上版本支持使用lambda表达式进行简洁的排序操作。例如: ```java List<String> list = new ArrayList<>(); // 添加元素到listlist.sort((s1, s2) -> s1.compareTo(s2)); ``` 4. 使用Stream API:Java 8及以上版本提供了Stream API,可以方便地对集合中的元素进行排序。例如: ```java List<Integer> list = new ArrayList<>(); // 添加元素到listList<Integer> sortedList = list.stream().sorted().collect(Collectors.toList()); ``` 以上是Java语言中List集合排序的几种常见方式,可以根据具体的需求选择适合的方法进行排序操作。 ### 回答3: 在Java语言中,对List集合进行排序的几种方式如下: 1. 使用Collections.sort()方法:可以通过调用Collections类的sort()方法对List集合进行排序。方法原型为: ```java public static <T extends Comparable<? super T>> void sort(List<T> list) ``` 此方法会使用集合元素的自然顺序进行排序。 2. 实现Comparable接口:若集合中的元素是自定义的对象,可以让对象实现Comparable接口,并重写其中的compareTo()方法来指定对象之间的比较规则。然后调用Collections.sort()方法对List集合进行排序。 3. 使用Comparator比较器使用Comparator接口的实现类来指定元素的比较规则。可以通过创建Comparator的实例,并重写compare()方法来实现自定义的比较规则。然后再调用Collections.sort()方法并传入Comparator参数进行排序。 4. 使用lambda表达式:在Java 8及以后的版本,可以使用lambda表达式对List集合进行排序。可以通过使用List的sort()方法,将Comparator接口的实现作为参数传入进行排序。例如: ```java list.sort((a, b) -> a.compareTo(b)); ``` 5. 使用Stream API:在Java 8及以后的版本,可以使用Stream API对List集合进行排序。通过调用List的stream()方法,再调用sorted()方法来进行排序。对于自定义对象,可以重写Comparable接口或使用Comparator指定排序规则。 总之,Java语言中对List集合进行排序可以通过调用Collections.sort()方法、实现Comparable接口、使用Comparator比较器使用lambda表达式或使用Stream API等方式来实现。具体选择哪种方式取决于业务需求和个人偏好。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值