Поскольку Date
реализует Comparable
, он имеет метод compareTo
, как и String
.
Так что ваш кастом Comparator
может выглядеть так:
public class CustomComparator implements Comparator<MyObject> {
@Override
public int compare(MyObject o1, MyObject o2) {
return o1.getStartDate().compareTo(o2.getStartDate());
}
}
Метод compare()
должен возвращать int
, поэтому вы не можете напрямую вернуть boolean
, как планировали в любом случае.
Ваш код сортировки будет примерно таким, как вы написали:
Collections.sort(Database.arrayList, new CustomComparator());
Немного более короткий способ написать все это, если вам не нужно повторно использовать ваш компаратор, это написать его как встроенный анонимный класс:
Collections.sort(Database.arrayList, new Comparator<MyObject>() {
@Override
public int compare(MyObject o1, MyObject o2) {
return o1.getStartDate().compareTo(o2.getStartDate());
}
});
Теперь вы можете написать последний пример в более короткой форме, используя лямбда-выражение для Comparator
:
Collections.sort(Database.arrayList,
(o1, o2) -> o1.getStartDate().compareTo(o2.getStartDate()));
И List
имеет метод sort(Comparator)
, так что вы можете сократить его еще больше:
Database.arrayList.sort((o1, o2) -> o1.getStartDate().compareTo(o2.getStartDate()));
Это настолько распространенная идиома, что есть встроенный метод для генерации Comparator
для класса с ключом Comparable
:
Database.arrayList.sort(Comparator.comparing(MyObject::getStartDate));
Все это эквивалентные формы.