import java.util.Arrays;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
import java.util.stream.Stream;
public class Test1 {
/*
Comparator.naturalOrder() 方法返回一个比较器,该比较器以自然顺序比较可比较对象
说明如何使用Comparator.naturalOrder与Stream.sorted、Collections.sort、List.sort和Arrays.sort一起对对象的集合进行自然排序。
*/
public static void main(String[] args) {
// Java 8中引入的Comparator.naturalOrder方法返回一个比较器,该比较器以自然顺序比较可比较对象
List<Integer> numList = Arrays.asList(12, 10, 15, 8, 11);
// 8 10 11 12 15
// Stream.sorted返回一个由这个流的元素组成的流,根据提供的比较器进行排序
numList.stream().sorted(Comparator.naturalOrder()).forEach(n-> System.out.print(n+" "));
System.out.println("\n---------------------------");
// 自然排序
List<String> strList = Arrays.asList("Varanasi", "Allahabad", "Kanpur", "Noida");
strList.stream().sorted(Comparator.naturalOrder()).forEach(s -> System.out.print(s + " "));
System.out.println("\n---------------------------");
// 反向
strList.stream().sorted(Comparator.reverseOrder()).forEach(s -> System.out.print(s + " "));
System.out.println("\n---------------------------");
// Collections.sort根据给定的比较器实例对指定的列表进行排序
Collections.sort(numList, Comparator.naturalOrder());
numList.forEach(n -> System.out.print(n + " "));
System.out.println("\n---------------------------");
// List.sort根据给定的比较器实例对这个列表进行排序
numList.sort(Comparator.naturalOrder());
numList.forEach(n -> System.out.print(n + " "));
System.out.println("\n-----------");
// Arrays.sort根据指定的比较器引起的顺序对指定的对象阵列进行排序
Integer[] array = {12, 10, 15, 8, 11};
// public static <T> void sort(T[] a, Comparator<? super T> c)
Arrays.sort(array, Comparator.naturalOrder());
for (Integer integer : array) {
System.out.print(integer+" ");
}
}
}
学习摘录:https://mp.weixin.qq.com/s/eHpr84Apj4glyFCAlfxKPQ