3 回答

TA贡献1898条经验 获得超8个赞
您可以使用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对象的自然顺序。使用a Comparator更灵活,因为不同的实现可以按名称,年龄等进行排序。
也可以看看
Java:实现Comparable和之间有什么区别Comparator?
为了完整起见,我应该提醒您注意,return o1.f - o2.f由于可能存在溢出,必须非常谨慎地使用“按减法比较”快捷方式(请阅读:有效的Java 2nd Edition:项目12:考虑实现Comparable)。大概曲棍球不是一项运动,运动员可以得分而导致进球=)

TA贡献1876条经验 获得超6个赞
Java 8只需一行:
Collections.sort(players, (p1, p2) -> p1.getGoalsScored() - p2.getGoalsScored());
添加回答
举报