案例:自定义 Book 类,里面包含 name 和 price,按 price 排序(从大到小)。
要求使用两种方式排序 , 有一个 Book[] books = 4 本书对象.
使用前面学习过的传递 实现 Comparator 接口匿名内部类,也称为定制排序。
可以按照 price (1)从大到小 (2)从小到大 (3) 按照书名长度从大到小
public class ArraysExercise {public static void main(String[] args) {Book[] books = new Book[4];books[0] = new Book("红楼梦", 100);books[1] = new Book("金瓶梅新版", 90);books[2] = new Book("青年文摘", 5);books[3] = new Book("百战Java合集", 300);// Arrays.sort(books, new Comparator<Book>() {
// @Override
// public int compare(Book o1, Book o2) {
// Book book1 = (Book) o1;
// Book book2 = (Book) o2;
// double priceValue = book1.getPrice()-book2.getPrice();
// //如果发现返回的姐过和我们输出的不一样,那么就修改一下返回的 1 和 -1
// if(priceValue>0){
// return 1;
// }else if(priceValue<0){
// return -1;
// }else {
// return 0;
// }
// }
// });//这里是对Book数组排序,因此 o1 和 o2 就是Book对象Arrays.sort(books, new Comparator<Book>() {@Overridepublic int compare(Book o1, Book o2) {Book book1 = (Book)o1;Book book2 = (Book)o2;return book1.getName().length()-book2.getName().length();
// double nameValue = book1.getName().length()-book2.getName().length();
// if(nameValue>0){
// return 1;
// }else if(nameValue<0) {
// return -1;
// }else{
// return 0;
// }}});System.out.println(Arrays.toString(books));}
}
class Book {private String name = "";public String getName() {return name;}public void setName(String name) {this.name = name;}public double getPrice() {return price;}public void setPrice(double price) {this.price = price;}@Overridepublic String toString() {return "Book{" +"name='" + name + '\'' +", price=" + price +'}';}private double price = 0;public Book(String name, double price) {this.name = name;this.price = price;}
}
以下是自己写的冒泡排序:(与该题设无关)
public static void Bubble(int arr[], Comparator c) {int temp = 0;for (int i = 0; i < arr.length - 1; i++) {for (int j = 0; j < arr.length - i - 1; j++) {if (c.compare(arr[j], arr[j + 1]) > 0) {temp = arr[j];arr[j] = arr[j + 1];arr[j + 1] = temp;}}}}