java – 使用比较器排序字符串长度

在尝试根据元素字符串长度对数组进行排序时,我遇到了编译错误.我有一套开始,

Set<String> arraycat = new HashSet<String>();
//add contents to arraycat
String[] array = arraycat.toArray(new String[0]);
//array looks like this now:
//array=[cat,cataaaa,cataa,cata,cataaa]

我理想的想要排序

array=[cat,cata,cataa,cataaa,cataaaa]

所以我有一个类型的比较器

class comp implements Comparator {

    public int compare(String o1, String o2) {
        if (o1.length() > o2.length()) {
            return 1;
        } else if (o1.length() < o2.length()) {
            return -1;
        } else {
            return 0;
        }
    }
}

然后我打电话给上课

Collections.sort(array, new comp());

但是,它抛出了两个编译错误:

comp is not abstract and does not override abstract method   compare(java.lang.Object,java.lang.Object) in java.util.Comparator
class comp implements Comparator {
^
testa.java:59: cannot find symbol
symbol  : method sort(java.lang.String[],comp)
location: class java.util.Collections
Collections.sort(array, new comp());
^2 errors

我很感激任何解决问题的线索.

最佳答案
您需要为Comparator指定一个类型参数才能使您的实现正常工作.

class comp implements Comparator<String> {
  public int compare(String o1, String o2) {
    if (o1.length() > o2.length()) {
      return 1;
    } else if (o1.length() < o2.length()) {
      return -1;
    } else {
      return 0;
    }
  }
}

在Java 1.7及更高版本中,您还可以将此方法的主体简化为:

class comp implements Comparator<String> {
  public int compare(String o1, String o2) {
    return Integer.compare(o1.length(), o2.length());
  }
}

此外,Collections.sort对List对象进行排序.由于您要对数组进行排序,因此应使用Arrays.sort

Arrays.sort(array, new comp());

转载注明原文:java – 使用比较器排序字符串长度 - 代码日志