我有以下LinkedHashset
它是LinkedHashset,因为我在添加时有很多重复的条目,它会阻止这种情况。
我如何对LinkedHashset进行排序
LinkedHashSet<String> uniqueStrings = new LinkedHashSet<>();
uniqueStrings.add("03/03/2016 00:00:00");
uniqueStrings.add("03/03/2016 00:30:00");
uniqueStrings.add("03/03/2016 01:00:00");
uniqueStrings.add("03/03/2016 00:30:00");
uniqueStrings.add("03/03/2016 00:01:00");
List<String> asList = new ArrayList<>(uniqueStrings);
System.out.println((asList+ "\n"));
答案 0 :(得分:2)
使用TreeSet和比较器将文本解析为Date。
private static Date safeParse(DateFormat dateFormat, String str) {
try {
return dateFormat.parse(str);
} catch (ParseException e) {
throw new RuntimeException(e);
}
}
public static void main(String[] args) {
DateFormat format = new SimpleDateFormat("MM/dd/yyyy HH:mm:ss");
Comparator<String> comparator = (a, b) -> safeParse(format, a).compareTo(safeParse(format, b));
Set<String> uniqueStrings = new TreeSet<>(comparator);
uniqueStrings.add("03/03/2016 00:00:00");
uniqueStrings.add("03/03/2016 00:30:00");
uniqueStrings.add("03/03/2016 01:00:00");
uniqueStrings.add("03/03/2016 00:30:00");
uniqueStrings.add("03/03/2016 00:01:00");
uniqueStrings.stream().forEach(System.out::println);
}