24

オブジェクトの単純なリストを長い順に並べ替えようとしています - 以下は、長い文字列の 1 つが小さい番号で始まるという理由だけで一番上にプッシュされるため、機能しません。だから私はこれらを実際の長い値で直接ソートする方法を探しています

現在の 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);
  }
}

my_objectsCollections.sort(my_objects)が次のような場所を呼び出します

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

実際にそこに long を格納してみませんか:

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」が 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 に答える