java compareto怎么用

 我来答
西安IT优就业
2017-12-01 · TA获得超过1561个赞
知道小有建树答主
回答量:1108
采纳率:90%
帮助的人:182万
展开全部
compareTo() 是 java.lang.Comparable 介面的唯一函式
性质上与 Object 的 equals() 很相似
不过在单纯的"相等比较"之外, 他还允许"次序比较"

如果某个 class 实现了 Comparable, 便是暗示其实体具有内在次序关系

在 Java 程式库里的所有 value classes 都实现了 Comparable

以下是 Comparable 的规格书
比较某个物件与另一指定物件的顺序. 当这个物件小於 等於 大於指定物件时, 分别传回负整数, 0, 正整数. 如果指定物件的型别不允许与这个物件进行比较, 就抛出 ClassCastException 异常

实作者必须确保, 对於所有的 x,y,z, 都能够满足 sgn(x.compareTo(y)) == -sgn(y.compareTo(x))
意味著 "x.compareTo(y) 抛出异常, 若且唯若(if and only if) y.compareTo(x) 抛出一个异常
.实作者必须确保数值间的关系具有迁移性, 也就是说 (x.compareTo(y)> && y.compareTo(z)>0) 意味 x.compareTo(z)>0
.实作者必须确保运算式 x.compareTo(y)==0 意味对於任意 z 而言, 运算式 sgn(x.compareTo(z)) == sgn(y.compareTo(z)) 永远成立
. 强烈建议(但不要求)满足 (x.compareTo(y)==0) == (x.equals(y)), 一般而言, 任何实现 Comparable interface 却违反本项条件之某个 class, 都应当明确告诉用户这一事实, 以下是大家推荐的说明方式 "次序相等的物件并不一定相等"

如果将 Comparable interface 与 Collection 的 package 相互应用, 我想是蛮强大的
简单的一个 Array, 如果里面的物件都有实作 Comparable, 那只要用

Arrays.sort(a);就可以搞定排序的问题了
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式