自然排序Comparable

 自然排序
*说明: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));

    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值