我有下面的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"));发布于 2016-03-07 20:07:23
使用带有比较器的TreeSet,该比较器分析文本到目前为止。
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);
}https://stackoverflow.com/questions/35852395
复制相似问题