Java集合排序——Comparable接口介绍、案例:对商品价格进行降序排列
Comparable接口概述
概述
(1) 此接口强行对实现它的每个类的对象进行整体排序
(2) 这种排序被称为类的自然排序,类的compareTo方法被称为它的自然比较方法
(3) 对于集合,通过调用Collections.sort方法进行排序
(4) 对于数组,通过调用Arrays.sort方法进行排序
(5) Comparable接口在java.lang包中
int compareTo(T o)方法
该对象小于、等于或者大于指定对象,则分别返回负整数、零或者正整数。
案例:对商品价格进行降序排列
商品类的创建、对compareTo方法的重写
public class Goods implements Comparable<Goods> {
private String id;//商品编号
private String name;//商品名称
private double price;//商品价格
//构造方法
public Goods(String id,String name,double price){
this.id=id;
this.name=name;
this.price=price;
}
//getter和setter方法
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
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;
}
public String toString(){
return "商品编号:"+id+",商品名称:"+name+",商品价格:"+price;
}
@Override
public int compareTo(Goods o) {
// 取出商品价格
double price1=this.getPrice();
double price2=o.getPrice();
int n=new Double(price2-price1).intValue();
return n;
}
}
注:这里intValue()
方法的作用是取整数部分。
测试
Collections.sort(goodsList);
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
public class GoodsTest {
public static void main(String[] args) {
Goods g1 = new Goods("s00001", "手机", 2000);
Goods g2 = new Goods("s00002", "冰箱", 5000);
Goods g3 = new Goods("s00003", "电视机", 3000);
List<Goods> goodsList = new ArrayList<Goods>();
goodsList.add(g1);
goodsList.add(g2);
goodsList.add(g3);
// 排序前
System.out.println("排序前:");
for (Goods goods : goodsList) {
System.out.println(goods);
}
Collections.sort(goodsList);
// 排序后
System.out.println("排序后:");
for (Goods goods : goodsList) {
System.out.println(goods);
}
}
}
运行结果:
排序前:
商品编号:s00001,商品名称:手机,商品价格:2000.0
商品编号:s00002,商品名称:冰箱,商品价格:5000.0
商品编号:s00003,商品名称:电视机,商品价格:3000.0
排序后:
商品编号:s00002,商品名称:冰箱,商品价格:5000.0
商品编号:s00003,商品名称:电视机,商品价格:3000.0
商品编号:s00001,商品名称:手机,商品价格:2000.0