美文网首页
java8 Stream

java8 Stream

作者: LinJF | 来源:发表于2019-12-02 15:02 被阅读0次

做个记录:
Person.java

import lombok.Data;

/**
 * @Description:
 * @Author: ljf  <lin652210786@163.com>
 * @Date: 2019/12/02
 */
@Data
public class Person {
    private String name;
    private int age;
    public Person(String name,int age){
        this.name = name;
        this.age = age;
    }
}

新建测试类:test.java

import java.util.*;
import java.util.concurrent.ConcurrentHashMap;
import java.util.function.Function;
import java.util.function.Predicate;
import java.util.stream.Collectors;

import static java.util.stream.Collectors.toList;

/**
 * @Description:  java8 Stream
 * @Author: ljf  <lin652210786@163.com>
 * @Date: 2019/12/02
 */
public class listtest {

    //java8 Stream
    public static void main(String[] args) {
        List<Person> list = new ArrayList<>();
        list.add(new Person("jack", 27));
        list.add(new Person("mike", 25));
        list.add(new Person("tom", 30));
        list.add(new Person("age", 31));

        //1.0 根据条件返回集合
        List a = new ArrayList();
        //filter(T -> boolean)
        a = list.stream().filter(Person -> Person.getAge() > 20).collect(toList());

        //2.0 distinct() 去重
        List<Person> list1 = new ArrayList<>();
        {
            list1.add(new Person("Core Java", 200));
            list1.add(new Person("Core Java", 200));
            list1.add(new Person("Learning Freemarker", 150));
            list1.add(new Person("Spring MVC", 300));
            list1.add(new Person("Spring MVC", 300));
        }
        long l1 = list.stream().distinct().count();
        System.out.println("No. of distinct books:"+l1);
        list1.stream().distinct().forEach(b -> System.out.println(b.getName()+ "," + b.getAge()));

        //2.1 去重
        List<String> list2 = Arrays.asList("AA", "BB", "CC", "BB", "CC", "AA", "AA");
        long l2 = list2.stream().distinct().count();
        System.out.println("No. of distinct elements:"+l2);
        String output = list2.stream().distinct().collect(Collectors.joining(","));
        System.out.println(output);

        //2.2 去重
        List<Person> list3 = new ArrayList<>();
        {
            list3.add(new Person("Core Java", 200));
            list3.add(new Person("Core Java", 300));
            list3.add(new Person("Learning Freemarker", 150));
            list3.add(new Person("Spring MVC", 200));
            list3.add(new Person("Hibernate", 300));
        }
        list3.stream().filter(distinctByKey(b -> b.getName()))
                .forEach(b -> System.out.println(b.getName()+ "," + b.getAge()));


        //3.0 排序
        //根据年龄大小来比较:
        /*list = list.stream()
                .sorted((p1, p2) -> p1.getAge() - p2.getAge())
                .collect(toList());*/

        //3.1 简化排序
        /*list = list.stream()
                .sorted(Comparator.comparingInt(Person::getAge))
                .collect(toList());*/

        //4.0 limit(long n)
        //返回前 n 个元素
        /*list = list.stream()
                .limit(2)
                .collect(toList());*/

        //5.0 skip(long n)
        //去除前 n 个元素
        /*list = list.stream()
                .skip(2)
                .collect(toList());*/

        // 5.1  先获取list集合的前两位元素 在获取的元素中取出第一位元素
        //limit  和 skip 灵活运用
        /*list = list.stream()
                .limit(2)
                .skip(1)
                .collect(toList());*/


        //6.0 map(T -> R)
        //将流中的每一个元素 T 映射为 R(类似类型转换)
        /*List<String> newlist =
                list.stream().map(Person::getName).collect(toList());*/


        //7.0 flatMap(T -> Stream)
        //将流中的每一个元素 T 映射为一个流,再把每一个流连接成为一个流
        //首先 map 方法分割每个字符串元素,但此时流的类型为 Stream,因为 split 方法返回的是 String[ ] 类型;
        // 所以我们需要使用 flatMap 方法,先使用Arrays::stream将每个 String[ ] 元素变成一个 Stream流,
        // 然后 flatMap 会将每一个流连接成为一个流,最终返回我们需要的 Stream
        List<String> list4 = new ArrayList<>();
        list4.add("aaa bbb ccc");
        list4.add("ddd eee fff");
        list4.add("ggg hhh iii");

        list4 = list4.stream().map(s -> s.split(" ")).
                flatMap(Arrays::stream).collect(toList());


        //8.0 anyMatch(T -> boolean)
        //流中是否有一个元素匹配给定的 T -> boolean 条件
        //是否存在一个 person 对象的 age 等于 20:
        boolean b = list.stream().anyMatch(person -> person.getAge() == 27);

        //9.0 allMatch(T -> boolean)
        //流中是否所有元素都匹配给定的 T -> boolean 条件
        boolean b1 = list.stream().allMatch(person -> person.getAge() == 27);

        //10.0 noneMatch(T -> boolean)
        //流中是否没有元素匹配给定的 T -> boolean 条件


        //11.0 findAny() 和 findFirst()
        //findAny():找到其中一个元素 (使用 stream() 时找到的是第一个元素;使用 parallelStream() 并行时找到的是其中一个元素)
        //findFirst():找到第一个元素
        //String b2 = list.stream().findFirst(person -> person);
        Person a5 = list.stream().filter(b5 -> "age".equals(b5.getName())).findAny().get();
        //添加orElse() 可以在不满足条件的情况下 自定义返回值  不会跑出异常
        Person a6 = list.stream().filter(b5 -> "age11".equals(b5.getName())).findAny().orElse(null);;
        System.out.println(a6);


        //13.0 计算年龄总和: 其中,reduce 第一个参数 0 代表起始值为 0,lambda (a, b) -> a + b 即将两值相加产生一个新值。
        int sum = list.stream().map(Person::getAge).reduce(0, (a1, c1) -> a1 + c1);
        //与之相同:
        int sum1 = list.stream().map(Person::getAge).reduce(0, Integer::sum);

        //计算年龄总乘积:
        int sum2 = list.stream().map(Person::getAge).reduce(1, (a2, c2) -> a2 * c2);
        //当然也可以
        Optional<Integer> sum3 = list.stream().map(Person::getAge).reduce(Integer::sum);

        //14.0 count()
        //返回流中元素个数,结果为 long 类型
        long l3 = list.stream().count();

        //15.0 collect()
        //收集方法,我们很常用的是 collect(toList()),当然还有 collect(toSet()) 等,参数是一个收集器接口,这个后面会另外讲。

        Set<Person> set = list.stream().collect(Collectors.toSet());

        //16.0 forEach()
        //返回结果为 void,很明显我们可以通过它来干什么了
        list.stream().forEach(System.out ::println);

        //向数据库插入新元素:
        //list.stream().forEach(PersonMapper::insertPerson);

        System.out.println("-------------------");
    }

    //distinct()功能
    private static <T> Predicate<T> distinctByKey(Function<? super T, ?> keyExtractor) {
        Map<Object,Boolean> seen = new ConcurrentHashMap<>();
        return t -> seen.putIfAbsent(keyExtractor.apply(t), Boolean.TRUE) == null;
    }

}

相关文章

  • Java8之Stream流(六)收集

    Java8之Stream流(一)基础体验 Java8之Stream流(二)关键知识点 Java8之Stream...

  • Java 8 Stream--开发手册

    什么是Java8 Stream,为什么需要Stream? Stream是Java8一大亮点,它与 java.io ...

  • Java8 学习笔记

    @(in action系列)[java8, lambda, stream] Java8 学习 java8 能高效的...

  • Stream流

    Stream流 java8新特性 Stream定义 A sequence of elements supporti...

  • java8 stream lambda

    记录Java8的stream操作,供自己复习。 创建Stream Employee类 创建stream方法 for...

  • JAVA8中Stream学习

    JAVA8中Stream学习 最近看了下Stream的api: Stream用户操作Collection族的数据,...

  • Java8 Stream 流的重用

    Java8 Stream 已经被操作或关闭 引言 在 java8 中,Stream 不能被重用,一旦它被使用或使用...

  • Java8 Stream 使用及其详解

    一、什么是Stream 二、Java7和Java8 聚合操作的区别。 三、Stream 总览 四、Stream 的...

  • Java 8 Stream 教程

    本文采用实例驱动的方式,对JAVA8的stream API进行一个深入的介绍。虽然JAVA8中的stream AP...

  • Java8新特性

    一、Lambda案例 案例1 案例2 二、Stream接口 Stream介绍 Stream在Java8中被定义为泛...

网友评论

      本文标题:java8 Stream

      本文链接:https://www.haomeiwen.com/subject/wvqfgctx.html