JDK8新特性之Stream

学习Stream之前建议先学Lambda的相关知识

前言:

Stream是Java 8 的一大亮点,很受开发人员的青睐。Stream 大大增强了集合对象功能,它专注于对集合对象进行各种非常便利、高效的聚合操作,或者大批量数据操作。Stream API 借助于java8中新出现Lambda 表达式,极大的提高编程效率和程序可读性。

Stream 的创建需要指定一个数据源,比如 java.util.Collection的子类,List或者Set, Map不支持。Stream的操作可以串行执行或者并行执行。

使用实例:

Class Person {
    private String name;
    private int age;
    ...
}

List<Person> list = new ArrayList<>();
list.add(new Person("jack", 20));
list.add(new Person("mike", 25));
list.add(new Person("tom", 30));

使用方法:

1、stream() / parallelStream() :将集合转为流

注:paralleStream()虽好,可不要滥用哦! 参考博客:

List list = new ArrayList();
// return Stream<E>

// 串行执行,即单线程  按照list原有顺序执行
list.stream();
list.stream().forEach(item ->{
        ...
    }
)

// 并行执行,即多线程  不一定按照list原有顺序执行
list.parallelStream();
list.parallelStream().forEach(item ->{
        ...
    }    
)

 2、filter(T -> boolean):保留boolean的元素

//保留年龄为 20 的 person 元素
list = list.stream()
            .filter(person -> person.getAge() == 20)
            .collect(toList());

//打印输出 [Person{name='jack', age=20}]

注:collect(toList()) 可以把流转换为 List 类型


 3、distinct() :去除重复元素


4、sorted() / sorted((T, T) -> int):对元素进行排序

 前提:流中的元素的类实现了 Comparable 接口

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

简化版:

list = list.stream()
           .sorted(Comparator.comparingInt(Person::getAge))
           .collect(toList());

5、limit(long n):返回前 n 个元素

list = list.stream()
            .limit(2)
            .collect(toList());

//打印输出 [Person{name='jack', age=20}, Person{name='mike', age=25}]

6、skip(long n):去除前 n 个元素

list = list.stream()
            .skip(2)
            .collect(toList());

//打印输出 [Person{name='tom', age=30}]
  • 用在 limit(n) 前面时,先去除前 m 个元素再返回剩余元素的前 n 个元素
  • limit(n) 用在 skip(m) 前面时,先返回前 n 个元素再在剩余的 n 个元素中去除 m 个元素
list = list.stream()
            .limit(2)
            .skip(1)
            .collect(toList());

//打印输出 [Person{name='mike', age=25}]

7、map(T -> R):将流中的每一个元素 T 映射为 R(类似类型转换)

//newlist 里面的元素为 list 中每一个 Person 对象的 name 变量

List<String> newlist = list.stream().map(Person::getName).collect(toList());

8、count():返回流中元素个数,结果为 long 类型 

long count = list.stream().filter(item -> item.getName().equals("jack")).count();


9、collect():收集方法 

//toList
//toSet
//toCollection
List newlist = list.stream.collect(toList());

 9.1、joining :连接字符串

 注:是一个比较常用的方法,对流里面的字符串元素进行连接,其底层实现用的是专门用于字符串连接的 StringBuilder。

String s = list.stream().map(Person::getName).collect(joining(","));

//结果:jack,mike,tom

9.2、maxBy/minBy :取最值

//取age最大值
Optional<Person> optional = list.stream().collect(maxBy(comparing(Person::getAge)));

10、forEach():循环遍历 

//打印各个元素:
list.stream().forEach(System.out::println);

11、forEachOrdered:严格控制顺序循环遍历 

List<String> strs = Arrays.asList("a", "b", "c");
strs.stream().forEachOrdered(System.out::print);//abc
System.out.println();
strs.stream().forEach(System.out::print);//abc
System.out.println();
strs.parallelStream().forEachOrdered(System.out::print);//abc
System.out.println();
strs.parallelStream().forEach(System.out::print);//bca

注:如果想要提高效率使用多线程执行,并且还要按照list原有顺序执行输出,可以使用parallelStream配合forEachOrdered() 


  • 11
    点赞
  • 64
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 5
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

技术杠精

你的鼓励是我创作最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值