Поскольку 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));
Все это эквивалентные формы.