妈妈真好三百字作文:compareTo这个JAVA方法是怎么用的?

来源:百度文库 编辑:高考问答 时间:2024/05/09 06:29:43

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);就可以搞定排序的问题了

=======================================================
枫舞添言:任何学习过程都是循序渐进的,只要努力没什么不能做到..作为任何问题,提前一步了解并不能说明就拥有了可以挖苦初学者的资本.

java的应用。看样子你还没有学会java,你问这种问题,对你的好处不大,还是踏踏实实的学习java吧。
=============
java是oop编程,网上有很多java社团、论坛,不过我看样子你并没有深入的学习过,否则,你怎么连这么基础的都不懂?况且,如果你入门了,多少也知道一些java的论坛吧。多少也有一些java的参考手册吧?呵呵,你没有。