java 8 新特性


Lambda表达式

Stream Api 流

参考 【Java 8 Streams API 详解】

  1. Java 8 Streams API 详解 – 胖毛 – 博客园 (cnblogs.com)
  2. Java基础系列-Collector和Collectors

一、Java8之前遍历List的方式

  1. Iterator迭代器

    Iterator<String> iterator = codeList.iterator();
    while (iterator.hasNext()){
     System.out.println(iterator.next());
    }
    
  2. for循环

    for (int i = 0; i < codeList.size(); i++){
     System.out.println(codeList.get(i));
    }
    
  3. 增强的for循环

    for (String code : codeList){
     System.out.println(code);
    }
    

二、Java8遍历List方式

Java8的forEach确实使用方便

codeList.forEach(a -> {
    System.out.println("code = " + a);
});

要对数据先过滤 != null,再遍历

codeList.stream()
        .filter(a -> a != null)
        .forEach(a -> System.out.println("code = " + a));

上面的a != null可以用下面语句简写

codeList.stream()
        .filter(Objects::nonNull)
        .forEach(a -> System.out.println("code = " + a));

三、并行流parallelStream的注意点

除了stream(), 还可以用parallelStream(), 在一些常见用parallelStream可以提高效率.

但是考虑到线程安全性, 我个人在工作中一般会注意下面事项

不要在parallelStream对集合写操作
不要在for循环中用parallelStream

四、有人说Java8 Stream forEach比较慢?

Java8是2014年发布的,现在都2022年了。

但是在工作中依然会碰到个别感觉自己很懂的人劝你不要用Java8 Stream。

这些人也就是网上看了点不专业的文章,写几个简单for循环和Stream比较。

在真实开发中,小批量数据的for循环和Java8 Stream差别不大,都挺快。

但是到业务复杂,处理比较耗时的情况,用并行流确实能提高效率,毕竟现在CPU都多核了。

这里不是吹Java8 Stream有多好,而是说在面对不同业务场景时,我们要用专业的眼光去选择用Iterator、for还是Stream。

原创文章,作者:3628473679,如若转载,请注明出处:https://blog.ytso.com/275151.html

(0)
上一篇 2022年7月18日
下一篇 2022年7月18日

相关推荐

发表回复

登录后才能评论