Comparablae接口

        在日常生经常涉及到排序的的问题,排序问题中又不得不涉及到比较的问题。在排序问题中根据不同的规则对多个对象进行比较,然后根据比较内容的不同对对象进行排序。java中的Comparable就是用来定义排序规则的接口。当要对类中的对象进行排序操作时,只需要实现Comparable接口中的compareTo()方法就实现对象中用于的比较规则。比如对一个班的学生进行排序可以根据身高排序,也可以根据体重排序还可以根据年龄排序,总之根据排序的规则不同,排序也不会相同。

        在java中compareTo方法的整体表述为:public int compareTo(Object obj),其中obj为比较的对象。在这个方法中,会将当前对象中的静态属性和obj对象的静态属性进行比较,如果当前对象的静态属性的值较大则返回值1,如果二者的值相等则返回值0,如果当前对象的静态属性的值较小则返回值-1。因此这也就决定了compareTo方法的的代码相对比较固定,这就意味着只要掌握了其中的典型代码然后在使用时在典型代码的基础上稍加修改就可以实现我们要的功能。

        比如compareTo方法的一个典型代码为:

        public int compareTo(Object obj){Man man = (Man) obj;if(this.age > man.age){return 1;}if(this.age < man.age){return -1;}if(this.age == man.age){return 0;}}

在这个代码中,只要对其中的比较部分进行修改就可以实现不同的比较规则。接下来用一个代码对compareTo方法的使用进行解释说明。

        在下面这个程序代码中创建了一个Man类用来实现Comparable接口,在Man类中定义了对应的属性,定义了全参构造方法,并且根据上面的典型compareTo方法实现了Comparable类中的方法。注意到,在实现时更改了比较对象,由典型方法中的age改为了id。随后在main方法中创建一组对象,并用数组msMans来接收。

        这里注意到一个问题,那就是在main方法中并没有直接调用compareTo方法,这里是因为java中的排序算法的底层原理都是基于compareTo方法的,也就是说,在方法sort中隐式调用了compareTo方法。这时,当对数组进行排序操作时,会直接对Man类中对象的id属性进行比较,并根据比较结果按大小将创建的对象进行从小到大排序。比如这个程序的执行结果为:

package cn.luoyusanshu.array;
import java.util.Arrays;
public class TestComparable {public static void main(String[] args) {Man[] msMans=  {new Man(3,10,"b"),new Man(60,111,"a"),new Man(2,1,"c")};Arrays.sort(msMans);System.out.println(Arrays.toString(msMans));}
}
class Man implements Comparable{int age;int id;String name;public Man(int age, int id, String name) {this.age = age;this.id = id;this.name = name;}public String toString(){return this.name+"\t"+this.id+"\t"+this.age;}public int compareTo(Object o){Man man = (Man) o;if(this.id < man.id){return -1;}if(this.id == man.id){return 0;}if(this.id > man.id){return 1;}return 0;}
}

        除此之外,上面这个程序中还有一点要注意,在进行比较时要注意比较属性的类型。在java中字符串类型和引用是无法用>、<符号进行比较的,所以这两个类型的数据无法作为排序的依据,比如将上面的程序进行修改,随便天加一个数组属性,这时如果按照数组属性对其进行排序操作,程序就会报错,如下所示:

package cn.luoyusanshu.array;
import java.util.Arrays;
public class TestComparable {public static void main(String[] args) {Man[] msMans=  {new Man(3,10,"b",new int[]{0}),new Man(60,111,"a",new int[]{3}),new Man(2,1,"c",new int[]{2})};Arrays.sort(msMans);System.out.println(Arrays.toString(msMans));}
}
class Man implements Comparable{int age;int id;String name;int[] a = new int[1];public Man(int age, int id, String name, int[] a) {this.age = age;this.id = id;this.name = name;this.a = a;}public String toString(){return this.name+"\t"+this.id+"\t"+this.age;}public int compareTo(Object o){Man man = (Man) o;if(this.a < man.a){return -1;}if(this.a== man.a){return 0;}if(this.a > man.a){return 1;}return 0;}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/614858.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MYSQL5.7详细安装步骤

MYSQL5.7详细安装步骤&#xff1a; 0、更换yum源 1、打开 mirrors.aliyun.com&#xff0c;选择centos的系统&#xff0c;点击帮助 2、执行命令&#xff1a;yum install wget -y 3、改变某些文件的名称 mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base…

C语言 | Leetcode C语言题解之第26题删除有序数组中的重复项

题目&#xff1a; 题解&#xff1a; int removeDuplicates(int* nums, int numsSize) {if (numsSize 0) {return 0;}int fast 1, slow 1;while (fast < numsSize) {if (nums[fast] ! nums[fast - 1]) {nums[slow] nums[fast];slow;}fast;}return slow; }

能看会说的人形机器人,对话的样子吓到我了

ChatGPT狂飙160天&#xff0c;世界已经不是之前的样子。 新建了免费的人工智能中文站https://ai.weoknow.com 新建了收费的人工智能中文站https://ai.hzytsoft.cn/ 更多资源欢迎关注 还记得这个表情宛如真人的人形机器人吗&#xff1f; ta被取名Ameca&#xff0c;由一家名为「…

模板方法模式:定义算法骨架的设计策略

在软件开发中&#xff0c;模板方法模式是一种行为型设计模式&#xff0c;它在父类中定义一个操作的算法框架&#xff0c;允许子类在不改变算法结构的情况下重定义算法的某些步骤。这种模式是基于继承的基本原则&#xff0c;通过抽象类达到代码复用的目的。本文将详细介绍模板方…

二维数组---刷题

一维数组不想更了&#xff0c;弄点二维数组&#xff01; 1.对角线 已知一个6*6的矩阵&#xff0c;把矩阵两条对角线上的元素加上10&#xff0c;然后输出这个新矩阵。 思路 题目简单&#xff0c;6*636&#xff0c;可以得知有36个元素。数组就定义成a[7][7]&#xff0c;难点在与…

[大模型]Yi-6B-Chat 接入 LangChain 搭建知识库助手

Yi-6B-Chat 接入 LangChain 搭建知识库助手 环境准备 在 autodl 平台中租赁一个 3090 等 24G 显存的显卡机器&#xff0c;如下图所示镜像选择 PyTorch–>2.0.0–>3.8(ubuntu20.04)–>11.8 接下来打开刚刚租用服务器的 JupyterLab&#xff0c;并且打开其中的终端开始…

Python编写一个抽奖小程序,新手入门案例,简单易上手!

“ 本篇文章将以简明易懂的方式引导小白通过Python编写一个简单的抽奖小程序&#xff0c;无需太多的编程经验。通过本文&#xff0c;将学习如何使用Python内置的随机模块实现随机抽奖&#xff0c;以及如何利用列表等基本数据结构来管理和操作参与抽奖的人员名单。无论你是Pytho…

私有化即时通讯软件,WorkPlus提供的私有化、安全通讯解决方案

在当今信息化快速发展的时代&#xff0c;安全问题已经成为各行各业关注的焦点。特别是在金融、政府单位和芯片等关键行业&#xff0c;信息安全的重要性不言而喻。这些行业涉及到大量的敏感数据和关键信息&#xff0c;一旦发生泄露&#xff0c;可能会对国家安全、企业利益甚至个…

Django中的静态文件、路径、访问静态文件的方法

1.什么是静态文件 不能与服务器端做动态交互的文件都是静态文件 如:图片,css,js,音频,视频,html文件(部分) 2.静态文件配置 在 settings.py 中配置一下两项内容: 1.配置静态文件的访问路径 通过哪个url地址找静态文件 STATIC_URL ‘/static/’ 说…

跟TED演讲学英文:Why AI will spark exponential economic growth by Cathie Wood

TED英文文稿 文章目录 TED英文文稿Why AI will spark exponential economic growthIntroductionVocabularyTranscriptSummary后记 Why AI will spark exponential economic growth Link: https://www.ted.com/talks/cathie_wood_why_ai_will_spark_exponential_economic_growth…

[Java、Android面试]_18_详解Handler机制 常见handler面试题(非常重要,非常高频!!)

本人今年参加了很多面试&#xff0c;也有幸拿到了一些大厂的offer&#xff0c;整理了众多面试资料&#xff0c;后续还会分享众多面试资料。 整理成了面试系列&#xff0c;由于时间有限&#xff0c;每天整理一点&#xff0c;后续会陆续分享出来&#xff0c;感兴趣的朋友可关注收…

vue 原理【详解】MVVM、响应式、模板编译、虚拟节点 vDom、diff 算法

vue 的设计模式 —— MVVM M —— Model 模型&#xff0c;即数据V —— View 视图&#xff0c;即DOM渲染VM —— ViewModel 视图模型&#xff0c;用于实现Model和View的通信&#xff0c;即数据改变驱动视图渲染&#xff0c;监听视图事件修改数据 初次渲染 将模板编译为 render …