- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试在 Java 中为需要按两个不同的列/变量进行排序的对象实现类似的接口(interface)。我尝试了多种方法,这是迄今为止最好的方法:
public int compareTo(Object o) {
Match m = (Match)o;
int diff = m.matches - matches;
if (diff == 0) {
if (distance > m.distance) {
return 1;
} else if (distance < m.distance) {
return -1;
} else {
return 0;
}
} else {
return diff;
}
}
但它仍然失败
java.lang.IllegalArgumentException: Comparison method violates its general contract!
知道我做错了什么吗?
旁注 1:如果 o 为 null 或属于不合适的类,则预计会出现 NPE/ClassCastExceptions - 这不是这里的问题。
旁注 2:我知道 change在 JDK 1.7 的排序算法中,但我真的不明白我在哪里违反了契约。因此关闭异常似乎是错误的解决方案。
最佳答案
既然你说distance
是 double ,您可能会遇到与此处描述的相同的问题:
Java error: "Comparison method violates its general contract!"
也许:
public int compareTo(Object o) {
Match m = (Match)o;
int diff = m.matches - matches;
if (diff == 0) {
return Double.compare(distance, m.distance);
} else {
return diff;
}
}
但是理想情况下,您应该使用内置的比较方法,如下所示。上面的代码是“需要最少改动”的示例,说明了关键问题。
此外,正如 @fabian-barney 在他的回答中指出的那样,您应该避免采用直接差异,而应使用内置的比较方法。所以你应该有这样的东西:
public int compareTo(Object o) {
Match m = (Match) o;
return m.matches == matches ? Double.compare(m.distance, distance) : Integer.compare(m.matches, matches);
}
这边,Double.compare
将为您处理 NaN 值。对于任何号码x
(NaN 除外)Double.compare(x, Double.NaN) == -1
将返回 true(即 NaN 被认为大于任何其他数字)。
请注意,您可以使用 ==
与 int
但它更复杂 double
因为Double.NaN != Double.NaN
。然而,new Double(Double.NaN).equals(Double.NaN)
是真的。请参阅Why is Java's Double.compare(double, double) implemented the way it is?进行愉快的讨论。
要查看一个示例,说明为什么如果您有 NaN,您的原始实现可能会违反约定,请参阅 Java compareTo documentation 。我们有:
Finally, the implementer must ensure that x.compareTo(y)==0 implies that sgn(x.compareTo(z)) == sgn(y.compareTo(z)), for all z.
假设你有x = NaN
和y = 5
和z = 6
,那么:
x.compareTo(y) == 0
(因为NaN > 5
和NaN < 5
是假的)x.compareTo(z) == 0
(同样的道理)y.compareTo(z) == -1
(y < z)。因此 2 和 3 (+ sgn
) 不等于所需的值。
关于java - .compareTo() 与 2 个排序列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11495625/
这似乎很奇怪,这并没有像我预期的那样工作。我编写了一个简单的java类,它实现Comparable接口(interface)并重写compareTo()方法。但是,它不允许我传递除对象之外的特定类型的
public int compareTo(Object another) throws CustomMadeException { if(this.getClass() != another.
早些时候,我在通用 IComparable 中获得了逆变的具体示例Jon Skeet 的界面。然而,这又产生了另一个问题。为什么不是通用的 List.Sort()方法能够推断出相同的信息? 我在这里提
我有注释 package javaannotationtest; import java.lang.annotation.*; @Target({ElementType.METHOD}) @Reten
我试图理解 C# 中的 CompareTo(),下面的示例让我比以往任何时候都更加困惑。有人能帮我理解为什么第三个变体的结果是 1 吗?句子“Hello wordd”中的第二个词与 str1“Hell
我已经在这个程序上工作了几天,并且在我的 BinarySearchTree 类中实现了一些主要方法,例如插入和删除。插入似乎工作正常,但是一旦我尝试删除,我就会不断出错。因此,在玩弄了代码之后,我想测
首先,我必须提到的是,在阅读了大量问题和教程并观看了一些视频后,问题仍然没有解决。 我是一名Java中级程序员,我编写了一些用于比较优先级队列中的元素的代码,其中元素的保存方式类似于[Comparab
我只是在为即将到来的考试做一些复习。我发现了我们的讲师给我们提供的这段代码供我们修改。 代码: public class Employee implements Comparable{ private
我的书要求我为一段代码编写 Javadoc 注释。大多数情况下,我了解如何执行 javadocs,但我不了解该程序在做什么。 “为类 Person 的以下方法编写 Javadoc 注释。假设类 Per
如果我写以下内容是否有可能溢出: public class SomeObj implements Comparable { private final float data; pub
我有一个名为任务的类,我想将其放入 PriorityQueue 中。 我的类(class)通过日期和名为isUrgent的 boolean 字段进行比较 @Override publ
这个问题已经有答案了: Java error: Comparison method violates its general contract (13 个回答) 已关闭 7 年前。 我有这个compa
我的类(class)结构: public class Priorityy implement Comparable { public int compareTo(Object pe) {
给定一个非负整数列表,我想对它们进行排列,使它们形成最大的数字。给定 [1, 20, 23, 4, 8],最大的形成数字是 8423201。但我想弄清楚compareTo 方法中变量的顺序如何影响 A
我想通过上次联系日期比较两个“收件人”,如果相同,则通过地址进行比较。这是我的代码: public class RecipientComparator implements Comparator {
package Comparable; public class Movie implements Comparable { private double rating; privat
您好,我在实现compareTo 方法时遇到问题。我一直在寻找答案,但没有任何帮助。我正在尝试用各种大小的圆圈填充 TreeSet。我需要在我的圈子类中使用compareTo 才能以这种方式存储它们。
我有以下代码;目的是返回数组中按字母顺序排列的最小成员。 public String smallest() { String smallest = ""; int i = 0; while(log[i
我有一个关于compareTo函数如何协助比较器进行排序的问题即 o1.compareTo(o2) 与 o2.compareTo(o1) 如果两个字符串相等,则此方法返回 0,否则返回正值或负值。如果
帮助我无法弄清楚compareTo函数。这就是我必须做的:编写一个compareTo函数,可用于根据以下内容按顺序放置产品到他们的零件号。也就是说,后面按字母顺序排列的零件号顺序大于按字母顺序排列较早
我是一名优秀的程序员,十分优秀!