web-dev-qa-db-ja.com

プロパティでオブジェクトの配列リストを並べ替える方法は?

ArraylistオブジェクトのHockeyPlayerがあるとしましょう。

それらがすべて変数int goalScoredを持っている場合、どのようにソートできますか。どのようにゴールでそれらをソートできますか?

36
sieve411

Collections.sort をカスタムの Comparator<HockeyPlayer> とともに使用できます。

    class HockeyPlayer {
        public final int goalsScored;
        // ...
    };

    List<HockeyPlayer> players = // ...

    Collections.sort(players, new Comparator<HockeyPlayer>() {
        @Override public int compare(HockeyPlayer p1, HockeyPlayer p2) {
            return p1.goalsScored - p2.goalsScored; // Ascending
        }

    });

比較部分は次のように書くこともできます。

players.sort(Comparator.comparingInt(HockeyPLayer::goalsScored));

または、HockeyPlayer implementsComparable<HockeyPlayer> にすることもできます。これは、すべてのHockeyPlayerオブジェクトのthe自然順序付けを定義します。 Comparatorを使用すると、さまざまな実装が名前、年齢などで順序付けできるという点で、より柔軟です。

こちらもご覧ください


完全を期すために、return o1.f - o2.f減算による比較のショートカットは、オーバーフローの可能性があるため、細心の注意を払って使用する必要があることに注意する必要があります(読み取り:Effective Java 2ndエディション:項目12:Comparable)の実装を検討します。おそらくホッケーは、問題を引き起こす量でプレーヤーがゴールを決めることができるスポーツではありません=)

こちらもご覧ください

88

@ user6158055が示唆するように、Java 8、 次のように:

Collections.sort(
                hockeyPlayerList,
                (player1, player2) -> player1.getGoalsScored()
                        - player2.getGoalsScored());

同じことを表す完全な例:

import Java.util.ArrayList;
import Java.util.Collections;
import Java.util.List;

public class Main {

    public static void main(String[] args) {
        List<HockeyPlayer> hockeyPlayerList = new ArrayList<>();
        hockeyPlayerList.add(new HockeyPlayer("A", 3));
        hockeyPlayerList.add(new HockeyPlayer("D", 10));
        hockeyPlayerList.add(new HockeyPlayer("B", 2));

        System.out.println("Before Sort based on goalsScored\n");

        hockeyPlayerList.forEach(System.out::println);

        System.out.println("\nAfter Sort based on goalsScored\n");

        Collections.sort(
                hockeyPlayerList,
                (player1, player2) -> player1.getGoalsScored()
                        - player2.getGoalsScored());

        hockeyPlayerList.forEach(System.out::println);
    }

    static class HockeyPlayer {

        private String name;
        private int goalsScored;

        public HockeyPlayer(final String name, final int goalsScored) {
            this.name = name;
            this.goalsScored = goalsScored;
        }

        public String getName() {
            return name;
        }

        public void setName(String name) {
            this.name = name;
        }

        public int getGoalsScored() {
            return goalsScored;
        }

        public void setGoalsScored(int goalsScored) {
            this.goalsScored = goalsScored;
        }

        @Override
        public String toString() {
            return "HockeyPlayer [name=" + name + ", goalsScored="
                    + goalsScored + "]";
        }

    }
}

出力

Before Sort based on goalsScored

HockeyPlayer [name=A, goalsScored=3]
HockeyPlayer [name=D, goalsScored=10]
HockeyPlayer [name=B, goalsScored=2]

After Sort based on goalsScored

HockeyPlayer [name=B, goalsScored=2]
HockeyPlayer [name=A, goalsScored=3]
HockeyPlayer [name=D, goalsScored=10]
6
Arpit

カスタム Comparator を作成してジョブを実行します。

3
duffymo

Java 8の1行だけ:

Collections.sort(players, (p1, p2) -> p1.getGoalsScored() - p2.getGoalsScored());
2
user6158055

Bean Comparator のような汎用コンパレーターを使用します。

2
camickr

Javaには、この種のことのためのsort()メソッドのセットがあります。詳細については、Collections.sort(およびComparable)を参照してください。

0
CWF

Java 8ではこれは簡単です

Collections.sort(playList, Comparator.comparingInt(HockeyPLayer::goalsScored))
0
Satyajit