实际项目当中根据需要进行选择 public class Jdk8Main { public static void main(String[] args) { List<Person> list = Lists.newArrayList( new Person("张1", 1, 1), new Person("张101", 101, 101), new Person("张1", 1, 1), new Person("张101", 101, 101), new Person("张2", 2, 2), new Person("张3", 3, 3), new Person("张4", 4, 4), new Person("张5", 5, 5), new Person("张6", 6, 6)); //取除集合中的重复元素 List<Person> list1 = list.stream().distinct().collect(Collectors.toList()); //排序,根据年龄进行排序 /* * 1.直接根据集合中的某个属性进行排序 * 2.对去重后的集合进行排序 */ List<Person> collect = list.stream().sorted((o1, o2) -> o1.getAge() - o2.getAge()).collect(Collectors.toList()); /** * 过滤操作 * filter : 获取的仍然是集合,包含当前条件的集合 */ List<Person> collect1 = list.stream().filter(person -> person.getAge() > 3).collect(Collectors.toList()); /** * 引射操作 * map:获取的是当前属性的集合,而不是当前对象的集合,这个与filter有区别 * 有以下两种写法 */ List<Integer> collect2 = list.stream().map(Person::getAge).collect(Collectors.toList()); //or List<Integer> collect3 = list.stream().map(person -> person.getAge()).collect(Collectors.toList()); /** * 统计 * Sum */ double sum = list.stream().mapToDouble(Person::getAge).sum(); /** * 分组 * list转换为map * groupingBy中的属性值对应的是map中的键key */ Map<Integer, List<Person>> collect4 = list.stream().collect(Collectors.groupingBy(Person::getAge)); /** * 多重分组 * groupingBy中的属性值对应的是map中的键key */ Map<String, Map<Integer, List<Person>>> collect5 = list.stream().collect(Collectors.groupingBy(t -> t.getName(), Collectors.groupingBy(t -> t.getAge()))); /** * 分组并计算综合 */ Map<String, Map<Integer, LongSummaryStatistics>> collect6 = list.stream().collect(Collectors.groupingBy(t -> t.getName(), Collectors.groupingBy(t -> t.getAge(), Collectors.summarizingLong(Person::getSize)))); /** * 集合比较的简写方式 */ list.sort((o1, o2) -> { return o1.getAge() - o2.getAge(); }); }
jdk1.8操作的api
最新推荐文章于 2024-09-06 23:13:04 发布