这两个接口适用于排序
Comparable接口和Comparator接口的区别
-
Comparable接口位于java.lang包下;Comparator位于java.util包下
-
Comparable接口只提供了一个compareTo()方法;Comparator接口不仅提供了compara()方法,还提供了其他默认方法,如reversed()、thenComparing(),使我们可以按照更多的方式进行排序
-
如果要用Comparable接口,则必须实现这个接口,并重写comparaTo()方法;但是Comparator接口可以在类外部使用,通过将该接口的一个匿名类对象当做参数传递给Collections.sort()方法或者Arrays.sort()方法实现排序。Comparator体现了一种策略模式,即可以不用要把比较方法嵌入到类中,而是可以单独在类外部使用,这样我们就可有不用改变类本身的代码而实现对类对象进行排序。
comparable接口的使用
· 必须要实现该接口才能发挥作用。
· 实现compareTo方法,这个接口也就只有这一个方法。
package cn.aaa.Test;
import java.net.URLConnection;
import java.util.Collections;
import java.util.LinkedList;
import java.util.List;
public class User implements Comparable<User> {
private int id;
private String name;
public User(int id, String name) {
this.id = id;
this.name = name;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public String toString() {
return "User{" +
"id=" + id +
", name='" + name + '\'' +
'}';
}
@Override
public int compareTo(User o) {
if(this.id<o.id){
return -1;
}else if(this.id==o.id){
return 0;
}else {
return 1;
}
}
public static void main(String[] args) {
List<User> users=new LinkedList<>();
User u1=new User(3,"aaa");
User u2=new User(1,"bbb");
User u3=new User(2,"ccc");
users.add(u1);
users.add(u2);
users.add(u3);
Collections.sort(users);
System.out.println(users);
}
}
conparator接口。
不会改变原有代码的结构,推荐使用
package cn.aaa.Test;
import java.util.Collections;
import java.util.Comparator;
import java.util.LinkedList;
import java.util.List;
public class People {
private int id;
private String name;
public People(int id, String name) {
this.id = id;
this.name = name;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public String toString() {
return "People{" +
"id=" + id +
", name='" + name + '\'' +
'}';
}
public static void main(String[] args) {
List<People> peoples=new LinkedList<>();
People p1=new People(1,"p1");
People p2=new People(3,"p2");
People p3=new People(2,"p3");
peoples.add(p1);
peoples.add(p2);
peoples.add(p3);
Collections.sort(peoples, new Comparator<People>() {
@Override
public int compare(People o1, People o2) {
if(o1.id>o2.id){
return 1;
}
else if(o1.id==o2.id){
return 0;
}
else {
return -1;
}
}
});
System.out.println(peoples);
}
}