3

我刚刚发现了这个考试问题,但无法弄清楚:

下面描述了一个人为的部分类,它实现了 Comparable 接口。这个人为类的唯一目的是将其实例与给定的字符串进行比较。

我们需要在课堂上填写两件事来完成它。这是课程:

public class PrivateComparableClass // FILL IN PART 1 { 
   private String thing;

    public PrivateComparableClass(String thing) {
     this.thing=thing;
    }
   //FILL IN PART 2
}

我假设第 1 部分仅对应于:

public class PrivateComparableClass implements Comparable {

第 2 部分,我假设他期待 compareTo 方法的实现,但我真的不知道如何正确地实现这个:

public static int compareTo() {
  if this.thing.equals(thing){
  return 1;
  } else {
    return -1;
  }
}

我将如何解决这个问题?

4

4 回答 4

5

首先,第 1 部分实际上应该是:

public class PrivateComparableClass implements Comparable<PrivateComparableClass> {

至于第 2 部分,如果thing是类中唯一的数据成员,您可以简单地捎带String.compareTo

public int compareTo(PrivateComparableClass rhs) {
  return this.thing.compareTo(rhs.thing);
}

我建议您阅读有关如何compareTo工作的内容(有三种可能的结果:小于、等于和大于)。

于 2011-05-17T22:23:28.397 回答
2

稍微扩展一下:

比较器函数通常接受两个参数(我们称它们为 A 和 B)并遵循返回的约定

  • -1 如果 A < B
  • 0 如果 A == B
  • 1 如果 A > B

此外,如果您使用实例变量,compareTo 不应声明为“静态”。

于 2011-05-17T22:31:00.993 回答
2

首先,Comparable接口是通用的;你的声明应该指定一个类型参数:

public class PrivateComparableClass 
  implements Comparable<PrivateComparableClass> {

然后,您应该在方法中比较thing类的成员compareTo()(这是一个实例方法,而不是类成员)。

@Override
public final int compareTo(PrivateComparableClass that) {
  return this.thing.compareTo(that.thing);
}

一个行为端正的Comparable人应该实现一个与其方法equals()一致的compareTo()方法:

@Override
public final boolean equals(Object obj) {
  if (obj == this)
    return true;
  if (!(obj instanceof PrivateComparableClass))
    return false;
  return compareTo((PrivateComparableClass) obj) == 0;
}

而且,当您覆盖时equals(),您也需要覆盖hashCode()

@Override
public final int hashCode() {
  return thing.hashCode();
}

如果thing确实允许null,则应在每个方法中添加适当的空值检查行为。

于 2011-05-17T22:33:36.220 回答
0

好吧,这或多或少是应该如何声明和实现类

public class PrivateComparableClass implements Comparable<PrivateComparableClass>
{
    private String thing;
    //... other stuff

    public int compareTo(PrivateComparableClass o)
    {
       return this.thing.compareTo(o.thing);
    }
}
于 2011-05-17T22:29:54.020 回答