我知道如何使用Arrays.sort()方法按以下方式对对象数组进行排序。
Arrays.sort(array of primitive type);
Arrays.sort(array of primitive type, from, to);
Arrays.sort(array of an object type);
Arrays.sort(array of an object type , from, to);
但我不知道遵循两种方法。
Arrays.sort(array of an object type , comparator);
Arrays.sort(array of an object type , from, to, comparator);
有人可以让我知道如何使用这些方法对类型对象的数组进行排序。我请求您添加代码或任何指向.java类的链接。我试图搜索它但找不到它。
感谢。
答案 0 :(得分:3)
示例:
class Person{
int id;
public getId(){return this.id;}
//Other stuff in your custom class
}
Person[] persons = ...;//An array of person you get from somewhere
Arrays.sort(persons,new Comparator<Person>(){
@Override
public int compare(Person p1, Person p2){
return p1.getId() - p2.getId();
}
} );
答案 1 :(得分:1)
很容易:
比较器界面使您可以控制对对象进行排序的方式。
对象可以基于您明智的键。
例如,应根据AccountNumber
对Account对象进行排序class Account {
String AccountNumber; //Key 1
String AccountName; //Key 2
String GovtID; //Key 3
}
您可以对三个键中的任何一个进行排序。
为了控制排序,你必须定义一个实现Comparator接口的类,它将定义用于排序的逻辑。
class SortAccountByNumber implements Comparator<Account> {
//Implement Unimplemented method
@Override
public int compare(Account a1, Account a2) {
//Read the specification for this method here in the Java Doc.
return 0;
}
}
现在使用它,只需调用
即可 SortAccountByNumber varSortAccountByNumber = new SortAccountByNumber();
Arrays.sort(arrayOfAccounts,varSortAccountByNumber);
答案 2 :(得分:0)
这是一个没有内联定义比较器的例子。
无论哪种方式都可以接受,但我认为这种方式更容易理解。
class Person {
int id;
public getId(){
return this.id;
}
}
class PersonComparator implements Comparator<Person> {
@Override
public int compareTo(Person personOne, Person personTwo) {
reuturn personOne.getId() - personTwo.getId();
}
}
用法:
Person[] personArray = buildArraySomehow();
PersonComparator pc = new PersonComparator();
Arrays.sort(personArray, pc);
Comparator是一个只有一个方法的接口:compareTo。
创建比较器时,这是您需要实现的唯一方法。
请注意, PersonComparator.compareTo()除了返回两个Person对象的ID之外什么都不做。
这是因为 compareTo()方法应该如何工作:
查看Comparator的文档以获取更多信息......
答案 3 :(得分:0)
对于复杂对象,Java不知道如何比较它们。因此,您需要编写一个Comparator。通常,您选择必须比较的类成员。
public class Comp implements Comparator<Test> {
@Override
public int compare(Test t, Test t1) {
return what_you_want_to_compare;
}
}