本文共 1466 字,大约阅读时间需要 4 分钟。
Arrays.sort可以对所有实现Comparable的对象进行排序。但如果有多种排序需求,如有时候需对name进行降序排序,有时候只需要对年龄进行排序。使用Comparable无法满足这样的需求。可以编写不同的Comparator来满足多样的排序需求。
1.编写PersonSortable2类属性:private name(String)、private age(int)
有参构造函数:参数为name,age toString方法:返回格式name-age 2 编写Comparator类编写NameComparator类,实现对name进行升序排序编写AgeComparator类,对age进行升序排序
3.main方法中
输入n输入n行name age,并创建n个对象放入数组对数组按照name进行升序排序后输出。在3的基础上对数组按照age进行升序排序后输出。最后最后两行使用如下代码输出NameComparator与AgeComparator所实现的所有接口。
System.out.println(Arrays.toString(NameComparator.class.getInterfaces()));
System.out.println(Arrays.toString(AgeComparator.class.getInterfaces()));输入样例:
5
zhang 15 zhang 12 wang 14 Wang 17 li 17输出样例:
NameComparator:sort
Wang-17 li-17 wang-14 zhang-15 zhang-12 AgeComparator:sort zhang-12 wang-14 zhang-15 Wang-17 li-17 //最后两行是标识信息import java.util.ArrayList;import java.util.Arrays;import java.util.Collections;import java.util.Comparator;import java.util.Scanner;class NameComparator implements Comparator{ @Override public int compare(PersonSortable2 o1, PersonSortable2 o2) { if(o1.getName().compareTo(o2.getName())>0) { return 1; }else if(o1.getName().compareTo(o2.getName())<0) { return -1; }else { return 0; } }}class AgeComparator implements Comparator { @Override public int compare(PersonSortable2 o1, PersonSortable2 o2) { if(o1.getAge()>o2.getAge()) { return 1; }else if(o1.getAge() a=new ArrayList (); for(int i=0;i
转载地址:http://jhbdi.baihongyu.com/