Arraylist
オブジェクトのHockeyPlayer
があるとしましょう。
それらがすべて変数int goalScoredを持っている場合、どのようにソートできますか。どのようにゴールでそれらをソートできますか?
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 implements
Comparable<HockeyPlayer>
にすることもできます。これは、すべてのHockeyPlayer
オブジェクトのthe自然順序付けを定義します。 Comparator
を使用すると、さまざまな実装が名前、年齢などで順序付けできるという点で、より柔軟です。
完全を期すために、return o1.f - o2.f
減算による比較のショートカットは、オーバーフローの可能性があるため、細心の注意を払って使用する必要があることに注意する必要があります(読み取り:Effective Java 2ndエディション:項目12:Comparable
)の実装を検討します。おそらくホッケーは、問題を引き起こす量でプレーヤーがゴールを決めることができるスポーツではありません=)
@ 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]
カスタム Comparator を作成してジョブを実行します。
Java 8の1行だけ:
Collections.sort(players, (p1, p2) -> p1.getGoalsScored() - p2.getGoalsScored());
Bean Comparator のような汎用コンパレーターを使用します。
Javaには、この種のことのためのsort()メソッドのセットがあります。詳細については、Collections.sort(およびComparable)を参照してください。
Java 8ではこれは簡単です
Collections.sort(playList, Comparator.comparingInt(HockeyPLayer::goalsScored))