Java 源码分析-Comparator Comparable 接口

java

Comparable 介绍

首先类要继承 Comparable 接口,还需要实现接口定义的比较方法,在这些方法中传入需要比较大小的另一个对象,通过选定的成员变量与之比较,如果大于则返回 1,小于返回 -1,相等返回 0。

Comparable 使用示例

public class People implements Comparable<People>{    

private String name;

private int age;

public People(String name, int age) {

super();

this.name = name;

this.age = age;

}

@Override

public int compareTo(People o) {

// 按年龄从小到大排序

if(this.age > o.getAge()) {

return 1;

} else if (this.age < o.getAge()) {

return -1;

}

// 相等情况

return 0;

}

}

排序测试:

import java.util.ArrayList;

import java.util.Collections;

public class Test {

public static void main(String[] args) {

People p1 = new People("fei", 35);

People p2 = new People("qiang", 22);

People p3 = new People("sheng", 24);

ArrayList<People> list = new ArrayList<People>();

list.add(p1);

list.add(p2);

list.add(p3);

Collections.sort(list);

for(People p:list) {

System.out.println("name:"+p.getName()+", age:"+p.getAge()+"。");

}

}

}

结果:

name:qiang, age:22。

name:sheng, age:24。

name:fei, age:35。

Comparator 使用示例

import java.util.Comparator;

public class PeopleComparator implements Comparator<People>{

@Override

public int compare(People o1, People o2) {

// 从大到小排序

if(o1.getAge() > o2.getAge()) {

return -1;

} else if (o1.getAge() < o2.getAge()) {

return 1;

}

return 0;

}

}

排序测试:

public class Test {    

public static void main(String[] args) {

People p1 = new People("fei", 35);

People p2 = new People("qiang", 22);

People p3 = new People("sheng", 24);

ArrayList<People> list = new ArrayList<People>();

list.add(p1);

list.add(p2);

list.add(p3);

// 指定一个比较器

list.sort(new PeopleComparator());

for(People p:list) {

System.out.println("name:"+p.getName()+", age:"+p.getAge()+"。");

}

}

}

结果:

name:fei, age:35。

name:sheng, age:24。

name:qiang, age:22。

两种方式比较

1、Comparable 是在类内部定义的方法实现的排序,Compartor 是在类外部实现的排序。

2、类实现了 Comparable 接口则表明这个类的对象之间是可以互相比较的,该类对象组成的集合可以直接使用 sort 方法排序。

3、Comparator 可以看成一种算法的实现,讲算法和数据分离,可以定义多个比较器实现比如升序、降序等。

以上是 Java 源码分析-Comparator Comparable 接口 的全部内容, 来源链接: utcz.com/z/393224.html

回到顶部