У меня есть список, который содержит даты в формате (MON-YYYY) в строковом формате, мне нужно отсортировать этот список. Подход, который я использовал до сих пор, - это чтение списка и преобразование строки в формате даты и использование параметра сравнения, но я не получаю желаемого результата
Фрагмент кода
List<String> abc = new ArrayList<String>();
List<Date> xyz = new ArrayList<Date>();
abc.add("JAN-2010");
abc.add("JAN-2011");
abc.add("APR-2013");
abc.add("NOV-2009");
try {
for (String abc1 : abc) {
Date date;
date = new SimpleDateFormat("MMM-yyyy", Locale.ENGLISH)
.parse(abc1);
xyz.add(date);
}
Collections.sort(xyz, new Comparator<Date>() {
public int compare(Date arg0, Date arg1) {
// return arg0.getDate().compareTo(o2.getDate());
return arg0.compareTo(arg1);
}
});
for (Date date1 : xyz) {
System.out.println("Sorted : " + date1);
}
} catch (ParseException e) {
e.printStackTrace();
}
}
Вывод
Sorted : Sun Nov 01 00:00:00 IST 2009
Sorted : Fri Jan 01 00:00:00 IST 2010
Sorted : Sat Jan 01 00:00:00 IST 2011
Sorted : Mon Apr 01 00:00:00 IST 2013
Ожидаемый результат
NOV-2009
JAN-2010
JAN-2011
APR-2013
Я также не уверен, что приведенный выше код идеален с точки зрения производительности, поскольку преобразование строки и синтаксический анализ заняли бы много времени, если бы в списке были тысячи дат в формате MON-YYYY.