自然排序 *说明:Java中的对象,正常情况下,只能进行比较:==或!=。不能使用<或> * 但是在开发场景中,我们需要比较对象的大小。 * 实现方法:使用Comparable或Comparator
* Comparable接口的使用:自然排序 * 1.String、包装类等实现了Comparable接口,重写了compareTo()方法 * 2.行了从小到大的排序 * 3.重写compareTo(obj)的规则: * 当前this大于形参onj,返回正整数 * 当前this小于形参onj,返回负整数 * 当前this等于形参onj,返回零 * 4.对于自定义类,如果需要排序,我们可以让自定义类实现Comparable接口 * 重写CompareTo(),在compareTo(obj)方法中指明如何排序
自定义商品类,按照价格升序排序
public class Goods implements Comparable{ private String name; private double price; public Goods(String name, double price) { this.name = name; this.price = price; } public void setName(String name) { this.name = name; } public void setPrice(double price) { this.price = price; } @Override public String toString() { return "Goods{" + "name='" + name + '\'' + ", price=" + price + '}'; } //指明商品比较大小的方式:按照价格从低到高 @Override public int compareTo(Object o) { if (o instanceof Goods){ Goods goods=(Goods)o; if (this.price>goods.price){ return 1; }else if (this.price<goods.price){ return -1; }else { return this.name.compareTo(goods.name); } // 方式二: // return Double.compare(this.price,goods.price); } throw new RuntimeException("传入的数据类型不一致"); } }
实现排序代码
public class GoodsTest { public static void main(String[] args) { Goods[] arr=new Goods[4]; arr[0]=new Goods("小米",9999); arr[1]=new Goods("苹果",5999); arr[2]=new Goods("三星",6999); arr[3]=new Goods("华为",1999); Arrays.sort(arr); System.out.println(Arrays.toString(arr)); } }