Java中comparator接口和Comparable接口的比较解析
作者:键盘林
这篇文章主要介绍了Java中comparator接口和Comparable接口的比较解析,Java提供了一个用于比较的接口Comparator和Comparable接口,提供了一个比较的方法,所有实现该接口的类,都动态的实现了该比较方法,需要的朋友可以参考下
Java提供了一个用于比较的接口Comparator和Comparable接口,提供了一个比较的方法,所有实现该接口的类,都动态的实现了该比较方法。
一、comparator接口
1、list的比较
如果要使用list的sort方法需要实现一个Comparator接口,自定义比较方式
public static void main(String[] args) { List<Integer> list= new ArrayList<>(); list.add(20); int i=0; while (i<10){ list.add(i++); } list.sort(new Comparator<Integer>() { @Override public int compare(Integer o1, Integer o2) { if (o1.intValue()>o2.intValue()){ return 1; }else if (o1.intValue()<o2.intValue()){ return -1; } return 0; } }); System.out.println(list.toString()); }
2、数组的比较
同理
Integer[] ins = {3, 5, 1, 6, 7}; Arrays.sort(ins, new Comparator<Integer>() { @Override public int compare(Integer o1, Integer o2) { if (o1.intValue()>o2.intValue()){ return 1; }else if (o1.intValue()<o2.intValue()){ return -1; } return 0; } }); System.out.println(Arrays.toString(ins));
二、Comparable接口
该接口是需要被你所需要排序的类所实现,违反了开闭原则。
需要排序的类实现comparable接口的方法
public class Person implements Comparable<Person> { public Integer getAge() { return age; } public Person(Integer age){ this.age=age; } public void setAge(Integer age) { this.age = age; } private Integer age; @Override public int compareTo(Person o) { return this.age<o.getAge()?1:(this.age==o.getAge()?0:-1); } }
public static void main(String[] args) { Person[] peoples={new Person(20),new Person(50),new Person(10)}; Arrays.sort(peoples); System.out.println(Arrays.toString(peoples)); }
运行结果
综合来说使用comparator接口更符合开发原则!
Comparator 和 Comparable 比较
Comparable是排序接口;若一个类实现了Comparable接口,就意味着“该类支持排序”。
而Comparator是比较器;我们若需要控制某个类的次序,可以建立一个“该类的比较器”来进行排序。
我们不难发现:Comparable相当于“内部比较器”,而Comparator相当于“外部比较器”。
到此这篇关于Java中comparator接口和Comparable接口的比较解析的文章就介绍到这了,更多相关Java的comparator接口和Comparable接口内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!