当前位置: 首页 > news >正文

接口使用实例——数组排序

对于基本数据类型的大小比较,我们可以使用<,>,=或者equals方法进行比较,但是对象之间如何进行比较呢?要对对象进行比较,我们必须对同一个成员变量进行比较,如我们可以通过比较name的大小来得出两个对象的大小,也可以通过比较age的大小来得出两个对象的大小。

一、对两个对象进行比较

public class Test{public static void main(String []args){Student student1=new Student("xiaoming",19);Student student2=new Student("zhangsan",12);System.out.println(student1.compareTo(student2));}
}
//首先,我们需要实现一个Comparable接口
class Student implements Comparable<Student>{String name;int age;public Student(String name, int age) {this.name = name;this.age = age;}
//重写接口的抽象方法,在方法中定义比较规则public int compareTo(Student o){//通过年龄进行比较//返回负数表示student1<student2,正数表示student1>student2,0表示student1=student2return this.age-o.age;}
}

执行结果:

如果要通过姓名进行比较,只需需改compareTo方法里的代码即可

 public int compareTo(Student o){//通过姓名进行比较return this.name.compareTo(o.name);}

二、对多个对象进行比较 

1.使用sort方法对自定义类型数组进行排序

import java.util.Arrays;public class Test{public static void main(String []args){Student[] students=new Student[3];students[0]=new Student("zhangsan",10);students[1]=new Student("lisi",19);students[2]=new Student("abc",8);System.out.println("排序前:"+ Arrays.toString(students));//能不能通过sort方法对Student类型的数组进行排序呢?Arrays.sort(students);System.out.println("排序后:"+Arrays.toString(students));}
}
//首先,我们需要实现一个Comparable接口
class Student implements Comparable<Student>{String name;int age;public Student(String name, int age) {this.name = name;this.age = age;}
//重写接口的抽象方法,在方法中定义比较规则public int compareTo(Student o){//通过姓名进行比较return this.name.compareTo(o.name);}
}

可以看到,这里是可以完成排序的,但是可以完成排序的原因是,我们实现了Comparable接口,并重写了compareTo方法,也就是说只要是自定义类型,要进行比较,就必须实现Comparable接口,对compareTo方法进行重写

2.模拟实现sort方法

import java.util.Arrays;public class Test{//向上转型,只要实现了Comparable接口的类都可以使用这个方法进行排序public static void mySort(Comparable[] comparables){//比较的趟数for (int i = 0; i < comparables.length-1; i++) {//每一趟比较的次数for (int j = 0; j < comparables.length-i-1; j++) {//通过compareTo方法来确定要根据对象的那个成员变量来比较大小if(comparables[j].compareTo(comparables[j+1])>0){Comparable ret=comparables[j];comparables[j]=comparables[j+1];comparables[j+1]=ret;}}}}public static void main(String []args){Student[] students=new Student[3];students[0]=new Student("zhangsan",10);students[1]=new Student("lisi",19);students[2]=new Student("abc",8);System.out.println("排序前:"+ Arrays.toString(students));mySort(students);System.out.println("排序后:"+Arrays.toString(students));}
}
class Student implements Comparable<Student>{String name;int age;public Student(String name, int age) {this.name = name;this.age = age;}public int compareTo(Student o){
//如要改为降序排序可以改为o.age-this.age;return this.age-o.age;}
}

三、Comparator接口(实现比较器)

在上面的例子中,我们发现,如果我们在compareTo方法中比较的是年龄,我们又想比叫姓名,就必须对这段代码进行修改,那么如何做到想对什么进行比较就对什么比较而不用修改代码呢?我们可以实现Comparator接口。

import java.util.Arrays;
import java.util.Comparator;@SuppressWarnings("ALL")
public class Test{public static void main(String []args){Student[] students=new Student[3];students[0]=new Student("zhangsan",10);students[1]=new Student("lisi",19);students[2]=new Student("abc",8);System.out.println("排序前:"+ Arrays.toString(students));AgeComparator ageComparator=new AgeComparator();Arrays.sort(students,ageComparator);System.out.println("排序后:"+Arrays.toString(students));NameComparator nameComparator=new NameComparator();Arrays.sort(students,nameComparator);System.out.println("排序后:"+Arrays.toString(students));}
}
class Student {String name;int age;public Student(String name, int age) {this.name = name;this.age = age;}}
//定义一个类实现Comparater接口,比较年龄
class AgeComparator implements Comparator<Student>{public int compare(Student o1,Student o2){return o1.age-o2.age;}}
//定义一个类实现Comparater接口,比较姓名
class NameComparator implements Comparator<Student>{public int compare(Student o1,Student o2){return o1.name.compareTo(o2.name);}}

相关文章:

  • (delphi11最新学习资料) Object Pascal 学习笔记---第13章第1节 (全局数据、栈和堆)
  • Android Audio基础——AudioFlinger回放录制线程(七)
  • 【NUCLEO-G071RB】007——IWDG-喂狗
  • 网站策划是什么
  • 专注于运动控制芯片、运动控制产品研发、生产与销售为一体的技术型芯片代理商、方案商——青牛科技
  • mac 系统正确安装nvm
  • 山东大学软件学院项目实训-创新实训-基于大模型的旅游平台(十九)- JUC(5)
  • 在Visual Studio Code和Visual Studio 2022下配置Clang-Format,格式化成Google C++ Style
  • linux的用户管理
  • 前端 MVC 分层的实践
  • 公司废弃的2014年群晖 DS215J 被我打包回家了,试玩一下
  • 世界上首位AI程序员诞生,AI将成为人类的对手吗?
  • Vue.js - Vue 的安装 以及 常用的 Vue 指令 【0基础向 Vue 基础学习】
  • Pytorch-08 实战:手写数字识别
  • 力扣刷题---3146. 两个字符串的排列差
  • 网络传输文件的问题
  • .pyc 想到的一些问题
  • Android单元测试 - 几个重要问题
  • CentOS学习笔记 - 12. Nginx搭建Centos7.5远程repo
  • css的样式优先级
  • Elasticsearch 参考指南(升级前重新索引)
  • interface和setter,getter
  • JavaScript新鲜事·第5期
  • java多线程
  • Java应用性能调优
  • Less 日常用法
  • LintCode 31. partitionArray 数组划分
  • Python_网络编程
  • rabbitmq延迟消息示例
  • redis学习笔记(三):列表、集合、有序集合
  • Travix是如何部署应用程序到Kubernetes上的
  • vue总结
  • 百度地图API标注+时间轴组件
  • 爬虫进阶 -- 神级程序员:让你的爬虫就像人类的用户行为!
  • 实战|智能家居行业移动应用性能分析
  • 数据结构java版之冒泡排序及优化
  • 王永庆:技术创新改变教育未来
  • 硬币翻转问题,区间操作
  • MiKTeX could not find the script engine ‘perl.exe‘ which is required to execute ‘latexmk‘.
  • HanLP分词命名实体提取详解
  • 仓管云——企业云erp功能有哪些?
  • 教程:使用iPhone相机和openCV来完成3D重建(第一部分) ...
  • 资深实践篇 | 基于Kubernetes 1.61的Kubernetes Scheduler 调度详解 ...
  • ​ 全球云科技基础设施:亚马逊云科技的海外服务器网络如何演进
  • ​香农与信息论三大定律
  • #1014 : Trie树
  • #NOIP 2014# day.1 T2 联合权值
  • #考研#计算机文化知识1(局域网及网络互联)
  • (day6) 319. 灯泡开关
  • (el-Transfer)操作(不使用 ts):Element-plus 中 Select 组件动态设置 options 值需求的解决过程
  • (Matalb回归预测)PSO-BP粒子群算法优化BP神经网络的多维回归预测
  • (poj1.2.1)1970(筛选法模拟)
  • (Redis使用系列) SpringBoot中Redis的RedisConfig 二
  • (超简单)使用vuepress搭建自己的博客并部署到github pages上
  • (二)windows配置JDK环境