使用流排序
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());