Java常用类(3)--Java比较器Comparable、Comparator类

简介: Java常用类(3)--Java比较器Comparable、Comparator类

文章目录


自然排序:java.lang.Comparable

定制排序:java.util.Comparator


自然排序:java.lang.Comparable


Comparable接口强行对实现它的每个类的对象进行整体排序,这种排序被称为类的自然排序。


实现 Comparable 的类必须实现 compareTo(Object obj) 方法,两个对象即通过 compareTo(Object obj) 方法的返回值来比较大小。


实现Comparable接口的对象列表(和数组)可以通过 Collections.sort 或

Arrays.sort 进行自动排序。实现此接口的对象可以用作有序映射中的键或有序集合中的元素,无需指定比较器。


像String、包装类等实现了Comparable接口,重写了compareTo(obj o)方法,给出了比较两个对象大小的方式。


像String、包装类重写compareTo()方法以后,默认可以进行从小到大的排列。


自定义类实现Comparable接口,重写compareTo(obj)的规则:


如果当前对象this大于形参对象obj,则返回正整数 1

如果当前对象this小于形参对象obj,则返回负整数 -1

如果当前对象this等于形参对象obj,则返回零 0


示例:


import java.util.Arrays;
class Good implements Comparable{
    private int price;
    private String name;
    public Good(String name,int price) {
        this.price = price;
        this.name = name;
    }
    @Override
    //先比较价格从低到高,再比较名称按从大到小
    public int compareTo(Object o) {
        if (o instanceof Good){
            Good other = (Good) o;
            if (this.price > other.price) return 1;
            else if (this.price < other.price) return -1;
            else return -this.name.compareTo(other.name);
        }
        throw new  RuntimeException("比较的不是Good!");
    }
    @Override
    public String toString() {
        return "Good{" +
                "price=" + price +
                ", name='" + name + '\'' +
                '}';
    }
}
public class ComparableTest {
    public static void main(String[] args) {
        Good[] goods = new Good[5];
        goods[0] = new Good("dell", 4668);
        goods[1] = new Good("ipad", 2628);
        goods[2] = new Good("dell", 688);
        goods[3] = new Good("huawei", 3229);
        goods[4] = new Good("xiaomi", 1688);
        Arrays.sort(goods);
        System.out.println(Arrays.toString(goods));
    }
}


Comparable 的典型实现类:(默认都是从小到大排列的)


①String:按照字符串中字符的Unicode值进行比较

②Character:按照字符的Unicode值来进行比较

③数值类型对应的包装类以及BigInteger、BigDecimal:按照对应的数值大小进行比较

④Boolean:true 对应的包装类实例大于 false 对应的包装类实例

⑤Date、Time等:后面的日期时间比前面的日期时间大


定制排序:java.util.Comparator


当元素的类型没有实现java.lang.Comparable接口而又不方便修改代码,或者实现了java.lang.Comparable接口的排序规则不适合当前的操作,那么可以考虑使用 Comparator 的对象来排序,强行对多个对象进行整体排序的比较。


重写compare(Object o1,Object o2)方法,比较o1和o2的大小:如果方法返回正整数,则表示o1大于o2;如果返回0,表示相等;返回负整数,表示o1小于o2。


可以将 Comparator 传递给 sort 方法(如 Collections.sort 或 Arrays.sort),从而允许在排序顺序上实现精确控制。


还可以使用 Comparator 来控制某些数据结构(如有序 set或有序映射)的顺序,或者为那些没有自然顺序的对象 collection 提供排序。


import java.util.Arrays;
import java.util.Comparator;
class Good {
    private int price;
    private String name;
    public Good(String name,int price) {
        this.price = price;
        this.name = name;
    }
    @Override
    public String toString() {
        return "Good{" +
                "price=" + price +
                ", name='" + name + '\'' +
                '}';
    }
    public int getPrice() {
        return price;
    }
    public String getName() {
        return name;
    }
}
public class ComparableTest {
    public static void main(String[] args) {
        Good[] goods = new Good[5];
        goods[0] = new Good("dell", 668);
        goods[1] = new Good("ipad", 928);
        goods[2] = new Good("dell", 928);
        goods[3] = new Good("huawei", 329);
        goods[4] = new Good("xiaomi", 168);
        Arrays.sort(goods,new Comparator(){
            @Override
            //先比较价格从低到高,再比较名称按从大到小
            public int compare(Object o1, Object o2) {
                Good good1 = (Good) o1;
                Good good2 = (Good) o2;
                if (good1.getPrice() > good2.getPrice()) return 1;
                else if (good1.getPrice() < good2.getPrice()) return -1;
                else return good1.getName().compareTo(good2.getName());
            }
        });
        System.out.println(Arrays.toString(goods));
    }
}


相关文章
|
21天前
|
算法 Java 数据处理
从HashSet到TreeSet,Java集合框架中的Set接口及其实现类以其“不重复性”要求,彻底改变了处理唯一性数据的方式。
从HashSet到TreeSet,Java集合框架中的Set接口及其实现类以其“不重复性”要求,彻底改变了处理唯一性数据的方式。HashSet基于哈希表实现,提供高效的元素操作;TreeSet则通过红黑树实现元素的自然排序,适合需要有序访问的场景。本文通过示例代码详细介绍了两者的特性和应用场景。
35 6
|
9天前
|
存储 安全 Java
java.util的Collections类
Collections 类位于 java.util 包下,提供了许多有用的对象和方法,来简化java中集合的创建、处理和多线程管理。掌握此类将非常有助于提升开发效率和维护代码的简洁性,同时对于程序的稳定性和安全性有大有帮助。
36 17
|
1天前
|
安全 Java
Java多线程集合类
本文介绍了Java中线程安全的问题及解决方案。通过示例代码展示了使用`CopyOnWriteArrayList`、`CopyOnWriteArraySet`和`ConcurrentHashMap`来解决多线程环境下集合操作的线程安全问题。这些类通过不同的机制确保了线程安全,提高了并发性能。
|
5天前
|
存储 Java 程序员
Java基础的灵魂——Object类方法详解(社招面试不踩坑)
本文介绍了Java中`Object`类的几个重要方法,包括`toString`、`equals`、`hashCode`、`finalize`、`clone`、`getClass`、`notify`和`wait`。这些方法是面试中的常考点,掌握它们有助于理解Java对象的行为和实现多线程编程。作者通过具体示例和应用场景,详细解析了每个方法的作用和重写技巧,帮助读者更好地应对面试和技术开发。
33 4
|
6天前
|
Java 编译器 开发者
Java异常处理的最佳实践,涵盖理解异常类体系、选择合适的异常类型、提供详细异常信息、合理使用try-catch和finally语句、使用try-with-resources、记录异常信息等方面
本文探讨了Java异常处理的最佳实践,涵盖理解异常类体系、选择合适的异常类型、提供详细异常信息、合理使用try-catch和finally语句、使用try-with-resources、记录异常信息等方面,帮助开发者提高代码质量和程序的健壮性。
13 2
|
10天前
|
存储 安全 Java
如何保证 Java 类文件的安全性?
Java类文件的安全性可以通过多种方式保障,如使用数字签名验证类文件的完整性和来源,利用安全管理器和安全策略限制类文件的权限,以及通过加密技术保护类文件在传输过程中的安全。
|
14天前
|
Java 数据格式 索引
使用 Java 字节码工具检查类文件完整性的原理是什么
Java字节码工具通过解析和分析类文件的字节码,检查其结构和内容是否符合Java虚拟机规范,确保类文件的完整性和合法性,防止恶意代码或损坏的类文件影响程序运行。
|
14天前
|
Java API Maven
如何使用 Java 字节码工具检查类文件的完整性
本文介绍如何利用Java字节码工具来检测类文件的完整性和有效性,确保类文件未被篡改或损坏,适用于开发和维护阶段的代码质量控制。
|
14天前
|
存储 Java 编译器
java wrapper是什么类
【10月更文挑战第16天】
20 3
|
17天前
|
Java 程序员 测试技术
Java|让 JUnit4 测试类自动注入 logger 和被测 Service
本文介绍如何通过自定义 IDEA 的 JUnit4 Test Class 模板,实现生成测试类时自动注入 logger 和被测 Service。
20 5
下一篇
无影云桌面