从我见过的所有排序方法示例中,我从未遇到过传递比较器定义的示例。如果比较器设计为返回负值、正值或 0 来对对象进行排序,那么排序方法会如何处理这些信息?sort 方法如何从 Comparator 定义中获取有意义的信息并执行其操作?
这是有问题的排序方法:
public void sort() {
library.sort(new BookComparator());
}
这是整个 Comparator 类:
import java.util.Comparator;
public class BookComparator implements Comparator<Book> {
public int compare(Book a, Book b) {
if(a == null || b == null) {
throw new NullPointerException();
}
int result = 0 ;
if(a.getAuthor() == null) {
if(b.getAuthor() != null) {
result = -1;
}
} else if(b.getAuthor() == null) {
result = 1;
} else {
result = a.getAuthor().compareTo(b.getAuthor());
}
if(result !=0) {
return result;
}
if(a.getTitle() == null) {
if(b.getTitle() != null) {
result = -1;
}
} else if(b.getTitle() == null) {
result = 1;
} else {
result = a.getTitle().compareTo(b.getTitle());
}
if(result !=0) {
return result;
}
if(a.getYear() < b.getYear()){
return -1;
} else if (a.getYear() == b.getYear()){
return 0;
} else {
return 1;
}
}
}
Qyouu
PIPIONE
相关分类