[Java开发之路](21)Comparator与Comparable

简介: 版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/SunnyYoona/article/details/50889774 1. Comparablepackage java.lang;import java.util.*;public interface Comparable {    public int compareTo(T o);}说明:Comparable 是排序接口。
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/SunnyYoona/article/details/50889774

1. Comparable

 
 
  1. package java.lang;
  2. import java.util.*;
  3. public interface Comparable<T> {
  4.    public int compareTo(T o);
  5. }

说明:

Comparable 是排序接口若一个类实现了Comparable接口,则该类可以支持排序。 假设现在存在实现Comparable接口的类的实例的List列表(或数组),则该List列表(或数组)可以通过 Collections.sort(或 Arrays.sort)进行排序


假设我们通过 x.compareTo(y) 来“比较x和y的大小”。若返回“负数”,意味着“x比y小”;返回“零”,意味着“x等于y”;返回“正数”,意味着“x大于y”。

举例:

 
  
  1. package com.qunar.test;
  2. /**
  3. * Created by xiaosi on 16-3-7.
  4. */
  5. public class Student implements Comparable<Student>{
  6.    private String name;
  7.    private int age;
  8.    public Student(String name, int age) {
  9.        this.name = name;
  10.        this.age = age;
  11.    }
  12.    public String getName() {
  13.        return name;
  14.    }
  15.    public void setName(String name) {
  16.        this.name = name;
  17.    }
  18.    public int getAge() {
  19.        return age;
  20.    }
  21.    public void setAge(int age) {
  22.        this.age = age;
  23.    }
  24.    @Override
  25.    public int compareTo(Student stu) {
  26.        if(age == stu.getAge()){
  27.            return name.compareTo(stu.getName());
  28.        }//if
  29.        else if(age > stu.getAge()){
  30.            return 1;
  31.        }
  32.        return -1;
  33.    }
  34. }


 
  
  1.        List<Student> stus = new ArrayList<Student>();
  2.        stus.add(new Student("xiaosi",24));
  3.        stus.add(new Student("sunny",24));
  4.        stus.add(new Student("yoona",21));
  5.        stus.add(new Student("kim",27));
  6.        Collections.sort(stus);
  7.        for(Student stu : stus){
  8.            System.out.println("age" + stu.getAge() + "   name->" + stu.getName());
  9.        }

以上实例实现的功能是:按student的age排序,如果年龄相同,则按name排序。


2. Comparator

 
 
  1. package java.util;
  2. public interface Comparator<T> {
  3.    int compare(T o1, T o2);
  4.    boolean equals(Object obj);
  5. }

说明:

若一个类本身不支持排序,并且没有实现Comparable接口。那么我们可以建立一个该类的比较器来进行排序。这个比较器只需要实现Comparator接口即可。我们可以通过比较器,然后通过该比较器对类进行排序。

举例:

 
  
  1. package com.qunar.test;
  2. /**
  3. * Created by xiaosi on 16-3-7.
  4. */
  5. public class Teacher {
  6.    private String name;
  7.    private int age;
  8.    public Teacher(String name, int age) {
  9.        this.name = name;
  10.        this.age = age;
  11.    }
  12.    public String getName() {
  13.        return name;
  14.    }
  15.    public void setName(String name) {
  16.        this.name = name;
  17.    }
  18.    public int getAge() {
  19.        return age;
  20.    }
  21.    public void setAge(int age) {
  22.        this.age = age;
  23.    }
  24. }

比较器:

 
  
  1. package com.qunar.test;
  2. import java.util.Comparator;
  3. /**
  4. * Created by xiaosi on 16-3-7.
  5. * Teacher比较器
  6. */
  7. public class TeacherComparator implements Comparator<Teacher>{
  8.    @Override
  9.    public int compare(Teacher o1, Teacher o2) {
  10.        if(o1.getAge() == o2.getAge()){
  11.            return o1.getName().compareTo(o2.getName());
  12.        }//if
  13.        else if(o1.getAge() > o2.getAge()){
  14.            return 1;
  15.        }
  16.        return -1;
  17.    }
  18. }

 
  
  1.        List<Teacher> teachers = new ArrayList<Teacher>();
  2.        teachers.add(new Teacher("xiaosi",24));
  3.        teachers.add(new Teacher("sunny",24));
  4.        teachers.add(new Teacher("yoona",21));
  5.        teachers.add(new Teacher("kim",27));
  6.        Collections.sort(teachers,new TeacherComparator());
  7.        for(Teacher te : teachers){
  8.            System.out.println("age" + te.getAge() + "   name->" + te.getName());
  9.        }

3. 比较

Comparable 是一个对象本身就已经支持自比较所需要实现的接口(如 String、Integer 自己就可以完成比较大小操作)。 Comparator 是一个专用的比较器,当这个对象不支持自比较或者自比较函数不能满足你的要求时,你可以写一个比较器来完成两个对象之间大小的比较。可以说一个是自己完成比较,一个是外部程序实现比较的差别而已。

用 Comparator 是策略模式(strategy design pattern),就是不改变对象自身,而用一个策略对象(strategy object)来改变它的行为。比如:你想对整数采用绝对值大小来排序,Integer 是不符合要求的,你不需要去修改 Integer 类(实际上你也不能这么做)去改变它的排序行为,只要使用一个实现了 Comparator 接口的对象来实现控制它的排序就行了。

Comparable使用:将比较方法写到实体类内对外声明所有比较规则统一按照这一种方式,代码的通用性差,如果改变一种比较规则,代码需要重写

Comparator使用:这种方式的比较实现了实体和比较规则的解绑,实现的比较规则可以根据自己的业务需求调用对应的比较类









目录
相关文章
|
5天前
|
Java 索引
Java String应用与开发
Java String应用与开发
13 0
|
6天前
|
安全 Java 开发者
构建高效微服务架构:后端开发的新范式Java中的多线程并发编程实践
【4月更文挑战第29天】在数字化转型的浪潮中,微服务架构已成为软件开发的一大趋势。它通过解耦复杂系统、提升可伸缩性和促进敏捷开发来满足现代企业不断变化的业务需求。本文将深入探讨微服务的核心概念、设计原则以及如何利用最新的后端技术栈构建和部署高效的微服务架构。我们将分析微服务带来的挑战,包括服务治理、数据一致性和网络延迟问题,并讨论相应的解决方案。通过实际案例分析和最佳实践的分享,旨在为后端开发者提供一套实施微服务的全面指导。 【4月更文挑战第29天】在现代软件开发中,多线程技术是提高程序性能和响应能力的重要手段。本文通过介绍Java语言的多线程机制,探讨了如何有效地实现线程同步和通信,以及如
|
9天前
|
安全 算法 Java
写给Java开发的Go语言协程实践
写给Java开发的Go语言协程实践
14 0
|
11天前
|
开发框架 前端开发 安全
Java从入门到精通:2.2.2学习使用Spring框架进行Web应用开发
Java从入门到精通:2.2.2学习使用Spring框架进行Web应用开发
|
11天前
|
设计模式 存储 前端开发
Java从入门到精通:2.2.1学习Java Web开发,了解Servlet和JSP技术,掌握MVC设计模式
Java从入门到精通:2.2.1学习Java Web开发,了解Servlet和JSP技术,掌握MVC设计模式
|
11天前
|
存储 算法 Java
盘点Java集合(容器)概览,Collection和Map在开发中谁用的最多?
盘点Java集合(容器)概览,Collection和Map在开发中谁用的最多?
27 0
|
16天前
|
Java API 开发者
Java 8新特性解析及其在企业级开发中的应用
【4月更文挑战第19天】本文将深入探讨Java 8的新特性,包括Lambda表达式、Stream API、Optional类等,并结合实例分析这些新特性在企业级开发中的优势和应用。通过阅读本文,您将了解到Java 8的新增功能以及如何在项目中灵活运用这些功能,提高代码质量和开发效率。
|
16天前
|
IDE Java 数据库连接
使用 Java 进行桌面应用开发
【4月更文挑战第19天】Java 是一款广泛应用于企业级、网络和桌面应用开发的编程语言。其跨平台特性使Java程序能在不同操作系统上运行,而JDK提供了开发所需工具和库。使用Swing等GUI库构建用户界面,结合JDBC进行数据库操作,Socket实现网络通信。虽然面临性能和用户体验的挑战,但通过优化和选用合适的IDE,Java仍能开发出高效稳定的桌面应用。
|
17天前
|
前端开发 Java Go
开发语言详解(python、java、Go(Golong)。。。。)
开发语言详解(python、java、Go(Golong)。。。。)
|
17天前
|
人工智能 前端开发 Java
Java语言开发的AI智慧导诊系统源码springboot+redis 3D互联网智导诊系统源码
智慧导诊解决盲目就诊问题,减轻分诊工作压力。降低挂错号比例,优化就诊流程,有效提高线上线下医疗机构接诊效率。可通过人体画像选择症状部位,了解对应病症信息和推荐就医科室。
163 10