集合排序: Comparator和Comparable的使用区别

  • Comparator接口
  • Comparable接口
  • 区别

在Java中使用集合来存储数据时非常常见的,集合排序功能也是常用功能之一.下面看一下如何进行集合排序,常用的方法有: ComparatorComparable

Comparator接口

使用步骤:

  • 新建比较类,
  • 实现Comparator接口,
  • 重写compare方法,
package sort;

import java.util.Comparator;

public class LuckBoyCompare implements Comparator<LuckBoy>{

    @Override
    public int compare(LuckBoy o1, LuckBoy o2) {
        return o1.getAge()-o2.getAge();
    }

}
  • 调用Collections.sort()方法进行排序,
  • 形式:Collections.sort(集合, 比较器实例).
@Test
public void test1() {
    List<LuckBoy> boyList = new ArrayList<LuckBoy>();
    LuckBoy boy1 = new LuckBoy("张三",13,"上海");
    LuckBoy boy2 = new LuckBoy("李四",12,"北京");
    LuckBoy boy3 = new LuckBoy("王五",18,"深圳");
    LuckBoy boy4 = new LuckBoy("马六",17,"南京");

    boyList.add(boy1);
    boyList.add(boy2);
    boyList.add(boy3);
    boyList.add(boy4);

    System.out.println("排序前:");
    for (LuckBoy luckBoy : boyList) {
        System.out.println(luckBoy);
    }

    System.out.println("排序后:");
    Collections.sort(boyList, new LuckBoyCompare());
    for (LuckBoy luckBoy : boyList) {
        System.out.println(luckBoy);
    }
}

LuckBoy.java

package sort;

public class LuckBoy{
    private String name;
    private Integer age;
    private String city;

    public LuckBoy() {
        super();
    }

    public LuckBoy(String name, Integer age, String city) {
        super();
        this.name = name;
        this.age = age;
        this.city = city;
    }

    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;
    }
    public String getCity() {
        return city;
    }
    public void setCity(String city) {
        this.city = city;
    }

    @Override
    public String toString() {
        return "LuckBoy [name=" + name + ", age=" + age + ", city=" + city + "]";
    }
}

打印结果:

排序前:
LuckBoy [name=张三, age=13, city=上海]
LuckBoy [name=李四, age=12, city=北京]
LuckBoy [name=王五, age=18, city=深圳]
LuckBoy [name=马六, age=17, city=南京]
排序后:
LuckBoy [name=李四, age=12, city=北京]
LuckBoy [name=张三, age=13, city=上海]
LuckBoy [name=马六, age=17, city=南京]
LuckBoy [name=王五, age=18, city=深圳]

Comparable接口

使用步骤:

  • 数据模型实现Comparable接口,
  • 重写compareTo方法,
package sort;

public class LuckBoy implements Comparable<LuckBoy>{
//TODO 中间代码省略
    @Override
    public int compareTo(LuckBoy o) {
        return this.age-o.age;
    }
}
  • 调用Collections.sort()方法进行排序,
  • 形式:Collections.sort(集合)
@Test
public void test2() {
    List<LuckBoy> boyList = new ArrayList<LuckBoy>();
    LuckBoy boy1 = new LuckBoy("张三",13,"上海");
    LuckBoy boy2 = new LuckBoy("李四",12,"北京");
    LuckBoy boy3 = new LuckBoy("王五",18,"深圳");
    LuckBoy boy4 = new LuckBoy("马六",17,"南京");

    boyList.add(boy1);
    boyList.add(boy2);
    boyList.add(boy3);

    boyList.add(boy4);

    System.out.println("============================");
    System.out.println("排序前:");
    for (LuckBoy luckBoy : boyList) {
        System.out.println(luckBoy);
    }

    System.out.println("排序后:");
    Collections.sort(boyList);
    for (LuckBoy luckBoy : boyList) {
        System.out.println(luckBoy);
    }
}

打印结果:

排序前:
LuckBoy [name=张三, age=13, city=上海]
LuckBoy [name=李四, age=12, city=北京]
LuckBoy [name=王五, age=18, city=深圳]
LuckBoy [name=马六, age=17, city=南京]
排序后:
LuckBoy [name=李四, age=12, city=北京]
LuckBoy [name=张三, age=13, city=上海]
LuckBoy [name=马六, age=17, city=南京]
LuckBoy [name=王五, age=18, city=深圳]

区别

Comparator 使用灵活,不需要修改源码.但是,使用时需要传入比较器对象;

Comparable 使用简单,但是需要修改源码.

原文地址:https://www.cnblogs.com/linyufeng/p/8465170.html

时间: 2024-10-24 13:19:49

集合排序: Comparator和Comparable的使用区别的相关文章

Java://Comparator、Comparable的用法(按照要求将set集合的数据进行排序输出):

import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; //comparator.comparable的用法(按照要求将map集合的键值对进行顺序输出) import java.util.List; public class Test { public static <T> void sop(T t) { System.out.println(t); } public stat

Comparator和Comparable在排序中的应用

当需要排序的集合或数组不是单纯的数字型时,通常可以使用Comparator或Comparable,以简单的方式实现对象排序或自定义排序. 一.Comparator 强行对某个对象collection进行整体排序的比较函数,可以将Comparator传递给Collections.sort或Arrays.sort. 接口方法: public class SalesItemComparatorByFirstLetter implements Comparator<SalesItem> { @Over

comparator接口与Comparable接口的区别

1. Comparator 和 Comparable 相同的地方 他们都是java的一个接口, 并且是用来对自定义的class比较大小的, 什么是自定义class: 如 public class Person{ String name; int age }. 当我们有这么一个personList,里面包含了person1, person2, persion3....., 我们用Collections.sort( personList ), 是得不到预期的结果的. 这时肯定有人要问, 那为什么可以

Comparator和Comparable的联系与区别

1.知识点了解 Comparator和Comparable都是用用来实现集合中元素的比较.排序的,所以,经常在集合外定义Comparator接口的方法和集合内实现Comparable接口的方法中实现排序 相同点: 二者的比较方法Comparable的compareTo和compare返回的结果有三种负数.零.正数,分别表示的关系为小于.等于.大于 不同点: Comparator位于java.util包下,属于Collection的一员:Comparable位于java.lang包下 Compar

comparable接口 和 comparator接口的特点与区别

1. Comparator 和 Comparable 相同的地方 他们都是java的一个接口, 并且是用来对自定义的class比较大小的. 什么是自定义class: 如 public class Person{ String name; int age }. 当我们有这么一个personList,里面包含了person1, person2, persion3....., 我们用Collections.sort( personList), 是得不到预期的结果的. 这时肯定有人要问, 那为什么可以排

接口Comparator和Comparable的区别和联系

1. Comparator 和 Comparable 相同的地方 他们都是java的一个接口, 并且是用来对自定义的class比较大小的. 什么是自定义class: 如 public class Person{ String name; int age; } 当我们有这么一个personList,里面包含了person1, person2, persion3....., 我们用Collections.sort( personList ), 是得不到预期的结果的. 这时肯定有人要问, 那为什么可以

SunnyAmy comparator接口与Comparable接口的区别

1. Comparator 和 Comparable 相同的地方 他们都是java的一个接口, 并且是用来对自定义的class比较大小的, 什么是自定义class: 如 public class Person{ String name; int age }. 当我们有这么一个personList,里面包含了person1, person2, persion3....., 我们用Collections.sort( personList ), 是得不到预期的结果的. 这时肯定有人要问, 那为什么可以

java中Comparator 和 Comparable的区别

1.Comparable的代码如下: public interface Comparable<T> { public int compareTo(T o); } 2.Comparator的代码如下 public interface Comparator<T> { int compare(T o1, T o2); boolean equals(Object obj); // jdk1.8 后的方法 default Comparator<T> reversed() { re

java中重写Comparator对两个list集合排序

public class test{ public static void main(String[] args) { List<LeaveRequest>  LvRequestList=new List<LeaveRequest>(); List<OtRequest> otRequestList=new List<OtRequest>(); List   allList=new List(); allList.addAll( LvRequestList);