本网站(662p.com)打包出售,且带程序代码数据,662p.com域名,程序内核采用TP框架开发,需要联系扣扣:2360248666 /wx:lianweikj
精品域名一口价出售:1y1m.com(350元) ,6b7b.com(400元) , 5k5j.com(380元) , yayj.com(1800元), jiongzhun.com(1000元) , niuzen.com(2800元) , zennei.com(5000元)
需要联系扣扣:2360248666 /wx:lianweikj
JavaSE中compare、compareTo的区别
吴振华 · 162浏览 · 发布于2023-05-15 +关注

本文主要介绍了JavaSE中compare、compareTo的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

 1.前言

在java当中,若是进行比较,大家可能第一时间想到,==或是!=,这种数学上的比较符>、

接下来,我就分别介绍并演示这两种实现方法。

2.环境说明

环境说明:Windows10 + Idea2021.3.2 + Jdk1.8 + SpringBoot 2.3.1.RELEASE

3.概述

3.1Comparable 简介

首先Comparable是一个排序接口,这也就表示若一个类实现了Comparable接口,则意味着该类支持排序。

public interface Comparable<T> {
    public int compareTo(T o);
}

3.2Comparable 定义

Comparable 接口仅提供了一个函数方法compareTo(),它的定义如下:

12e0e66c9f9772b1f8ea26f148ec21d0_2023051414495313.png

那具体该方法有何作用呢?请接着往下看。

compareTo()方法返回的是一个int类型值, 这里我着重给大家介绍一下。

若你使用compareTo()进行a与b的比较,eg:a.compareTo(b),那么,返回值有三种结果情况,分别如下:

  • 若返回值为负数,则说明a

  • 若返回值为0,则说明a=b;

  • 若返回值为正数,则说明a>b;

其中,String类就是一个典例,它就是实现了Comparable接口。

5ed405103e7838f6b49cdd1680dd5dad_2023051414495314.png

 其中就重写了Comparable接口中的compareTo()方法,具体实现逻辑大家可以借鉴。

8a6c53b0fa7393f36295b51b73e1f095_2023051414495315.png

3.3Comparator 简介

接下来,我再给大家讲解一下Comparator接口。

首先Comparator是一个比较器接口,用于类设计已经完成,还想排序(Arrays)的情况下使用。

目前它只提供了两个函数供使用。

public interface Comparator<T> {
    int compare(T o1, T o2);
    boolean equals(Object obj);
}

3.4Comparator 定义

针对Comparator接口,若一个类实现了它,只需要实现compare()方法即可,可以不用实现equals方法,因为任何类的超类都是Object,查看Object类也可得知equals()就被实现了。

该方法 int compare(T a, T b) 是“比较a和b的大小”。返回值结果情况与compareTo()方法一致,具体如下:


  • 若返回值为负数,则说明a

  • 若返回值为0,则说明a=b;

  • 若返回值为正数,则说明a>b;

3.5区别

方法的比较

1.compareTo(Object obj)方法是java.lang.Comparable接口中的方法, 当需要对类的对象进行排序时,该类需要实现Comparable接口,必须重写compareTo(T o)方法。

比如String类等一些类默认实现了该接口,重写了 compareTo()方法,例如s1.compareTo(s2),自然返回值就是s1 与 s2 的ASC码差值,其实就是字典排序;

2.compare(Object o1, Object o2)方法是java.util.Comparator接口的方法, 它实际上用的是待比较对象的compare(T o1, T o2)方法;

3、Comparable 是排序接口,而Comparator 是比较器接口。

4. 实例演示

4.1.Comparable使用演示

接下来我先给大家演示下如何实现Comparable接口的compareTo()方法进行排序。

@Data
public class Dog implements Comparable<Dog> {
    private String type;
    private double price;
    public Dog() {
    }
    public Dog(String name, int price) {
        this.type = name;
        this.price = price;
    }
    public String toString() {
        return "狗品种为:" + type + ",价格为:" + price;
    }
    @Override
    public int compareTo(Dog o) {//升序
        if (this.price > o.price) {
            return 1;
        } else if (this.price < o.price) {
            return -1;
        }
        return 0;
    }
}

写个main函数进行测试验证。演示代码如下:

public class ComparableTest {
    public static void main(String[] args) {
        Dog[] dogs = {
                new Dog("泰迪", 10),
                new Dog("柯基", 78),
                new Dog("柴犬", 55),
                new Dog("藏獒", 42),
                new Dog("斗牛犬", 15)
        };
        //升序
        Arrays.sort(dogs);
        for (Dog dog : dogs) {
            System.out.println(dog);
        }
    }
}

执行main函数,控制台打印如下:

c51b68632af6712fc63cc938ba16bc50_2023051414495316.png

 我们再调整一下排序规则,改为按对象中price价格进行降序。

@Override
public int compareTo(Dog o) {//降序
    if (this.price < o.price) {
        return 1;
    } else if (this.price > o.price) {
        return -1;
    }
    return 0;
}

再来看下价格。

f0488c9352e55eaa1b700bf11270f4d2_2023051414495317.png

4.2 Comparable使用演示

我们来实现一个比较器,实现Comparator接口的compare()方法,其中泛型我直接指定Dog对象。演示代码具体如下:

public class ComparatorDog implements Comparator<Dog> {
    @Override
    public int compare(Dog o1, Dog o2) {
        //升序
        if (o1.getPrice() > o2.getPrice()) {
            return 1;
        } else if (o1.getPrice() < o2.getPrice()) {
            return -1;
        }
        return 0;
    }
}



写个测试类进行测试用例打印:

public static void main(String[] args) {
    Dog[] dogs = {
            new Dog("泰迪", 10),
            new Dog("柯基", 78),
            new Dog("柴犬", 55),
            new Dog("藏獒", 42),
            new Dog("斗牛犬", 15)
    };
    //升序
    Arrays.sort(dogs,new ComparatorDog());
    for (Dog dog : dogs) {
        System.out.println(dog);
    }
}

接下来运行main函数,大家请看控制台输出截图:

247df03998ddf9f05079bbd46c932f69_2023051414495318.png

我们稍微调整下排序规则,将升序改为降序。具体修改如下:

@Override
public int compare(Dog o1, Dog o2) {
    //降序
    if (o1.getPrice() < o2.getPrice()) {
        return 1;
    } else if (o1.getPrice() > o2.getPrice()) {
        return -1;
    }
    return 0;
}

我们运行main函数输出结果如下截图:

d8b78307ae441335bebae9d72f45d90d_2023051414495319.png


相关推荐

PHP实现部分字符隐藏

沙雕mars · 1325浏览 · 2019-04-28 09:47:56
Java中ArrayList和LinkedList区别

kenrry1992 · 908浏览 · 2019-05-08 21:14:54
Tomcat 下载及安装配置

manongba · 970浏览 · 2019-05-13 21:03:56
JAVA变量介绍

manongba · 963浏览 · 2019-05-13 21:05:52
什么是SpringBoot

iamitnan · 1086浏览 · 2019-05-14 22:20:36
加载中

0评论

评论
坐标是江苏.南京,行业是互联网,技术是PHP和java,还有熟悉前后端等。
分类专栏
小鸟云服务器
扫码进入手机网页