24

我正在尝试按 long 对一个简单的对象列表进行排序 - 下面不起作用,因为其中一个长字符串被推到顶部只是因为它以较低的数字开头。所以我正在寻找一种方法来直接按实际的 long 值对它们进行排序

当前的 obj 实现如下所示。在我使用这个的类中,我调用 Collections.sort(trees);

public class Tree implements Comparable<Tree> {
    public String dist; //value is actually Long

    public int compareTo(Tree o) {
        return this.dist.compareTo(o.dist);
    }
}
4

6 回答 6

43

Long.compare( x , y )

如果您有一个要对long值进行排序的对象,并且它实现了Comparable,则在 Java 7+ 中您可以使用Long.compare(long x, long y)(返回一个int

例如

public class MyObject implements Comparable<MyObject>
{
  public long id;

  @Override
  public int compareTo(MyObject obj) {
    return Long.compare(this.id, obj.id);
  }
}

调用Collections.sort(my_objects)my_objects 类似于

  List<MyObject> my_objects = new ArrayList<MyObject>();
  // + some code to populate your list
于 2014-10-20T07:46:24.947 回答
20

为什么不实际存储很长时间:

public class Tree implements Comparable<Tree> {
    public long dist; //value is actually Long

    public int compareTo(Tree o) {
        return this.dist<o.dist?-1:
               this.dist>o.dist?1:0;
    }
}

或者先比较字符串的长度,然后比较它们

public String dist; //value is actually Long
public int compareTo(Tree o) {
    if(this.dist.length()!=o.dist.length())
          return this.dist.length()<o.dist.length()?-1:1;//assume the shorter string is a smaller value
    else return this.dist.compareTo(o.dist);
}
于 2011-05-30T12:18:27.540 回答
13

好吧,如果 dist 变量实际上很长,那么您可以尝试使用

public int compareTo(Tree o) {
    return Long.valueOf(this.dist).compareTo(Long.valueOf(o.dist));
}
于 2011-05-30T12:09:31.037 回答
5

只是我使用 Long 比较器按日期对文件进行排序的示例:

public File[] getAllFoldersByDescendingDate(File folder) {
    if (!folder.isDirectory()) {
        return null;
    }
    allFiles = folder.listFiles();
    Arrays.sort(allFiles, new Comparator<File>()
    {
        public int compare(final File o1, final File o2)
        {
            return Long.compare(o2.lastModified(), o1.lastModified());
        }
    });
    return allFiles;
}
于 2015-12-04T01:00:07.287 回答
3

这取决于你想怎么做事?您想保留 Comparable 的当前实现吗?如果是,请使用带有 Comparator 的 sort 方法并实现一个自定义比较器,该比较器使用字符串 ( Long.parseLong(dist)) 的实际“长”值。如果否,则只需修改当前compareTo并使用“dist”的 Long 值。

顺便说一句,我会重新审视逻辑并问自己为什么“dist”实际上是 Long 类型时是 String 类型?

于 2011-05-30T12:04:24.897 回答
0

为什么不

public class Tree implements Comparable<Tree> {
    public Long dist;

    public int compareTo(Tree o) {
        return this.dist.compareTo(o.dist);
    }
}
于 2011-05-30T12:09:28.813 回答