题目1:使用 Arrays 对对象数组排序(Comparator 与 Lambda)
需求:
定义一个 Product 类,包含属性:name(String)、price(double)。创建包含 4 个产品的数组。
-
使用
Arrays.sort结合匿名内部类Comparator按价格升序排序。 -
使用 Lambda 表达式简化上述排序。
-
输出排序后的结果。
要求:
-
Product类需提供构造方法、getter/setter 和toString。 -
展示两种排序写法,并说明输出。
java
package com.study.test;
public class Product {
private String name;
private Double price;
public Product() {
}
public Product(String name, Double price) {
this.name = name;
this.price = price;
}
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;
}
@Override
public String toString() {
return "Product{" +
"name='" + name + '\'' +
", price=" + price +
'}';
}
}
java
public class Test {
public static void main(String[] args) {
Product[] products = new Product[4];
products[0] = new Product("手机", 2999.0);
products[1] = new Product("电脑", 5999.0);
products[2] = new Product("耳机", 399.0);
products[3] = new Product("鼠标", 89.0);
System.out.println("排序前:"+Arrays.toString(products));
Arrays.sort(products, new Comparator<Product>() {
@Override
public int compare(Product p1, Product p2) {
return Double.compare(p1.getPrice(), p2.getPrice());
}
});
System.out.println("匿名内部类方式:"+Arrays.toString(products));
Arrays.sort(products,( o1, o2) -> Double.compare(o1.getPrice(),o2.getPrice()));
System.out.println("Lambda表达式升序:"+Arrays.toString(products));
}
}
