使用流排序

List<String> data = new ArrayList<>();
data.add("Sydney");
data.add("London");
data.add("New York");
data.add("Amsterdam");
data.add("Mumbai");
data.add("California");

System.out.println(data);

List<String> sortedData = data.stream().sorted().collect(Collectors.toList());

System.out.println(sortedData);

输出:

[Sydney, London, New York, Amsterdam, Mumbai, California]
[Amsterdam, California, London, Mumbai, New York, Sydney]

也可以使用不同的比较机制,因为有一个重载的 sorted 版本,它以比较器为参数。

此外,你可以使用 lambda 表达式进行排序:

List<String> sortedData2 = data.stream().sorted((s1,s2) -> s2.compareTo(s1)).collect(Collectors.toList());

这将输出 [Sydney, New York, Mumbai, London, California, Amsterdam]

你可以使用 Comparator.reverseOrder() 来建立一个比较器来强加自然顺序的 reverse

List<String> reverseSortedData = data.stream().sorted(Comparator.reverseOrder()).collect(Collectors.toList());