JavaSE之 I/O流(一) stream

简介: JavaSE之 I/O流(一) stream

Stream

概述

Stream 流其实就是一根传送带,元素在上面可以被 Stream 流操作

  • 可以解决已有集合类库或者数组 API 的弊端
  • Stream 流简化集合和数组的操作
  • 链式编程
 list.stream().filter(new Predicate<String>() {
             @Override
             public boolean test(String s) {
                 return s.startsWith("张");
             }
         });
 ​
 list.stream().filter(s -> s.startsWith("张"));

获取流

集合获取 Stream 流用:default Stream<E> stream()

数组:Arrays.stream(数组) / Stream.of(数组);

 // Collection集合获取Stream流。
 Collection<String> c = new ArrayList<>();
 Stream<String> listStream = c.stream();
 ​
 // Map集合获取流
 // 先获取键的Stream流。
 Stream<String> keysStream = map.keySet().stream();
 // 在获取值的Stream流
 Stream<Integer> valuesStream = map.values().stream();
 // 获取键值对的Stream流(key=value: Map.Entry<String,Integer>)
 Stream<Map.Entry<String,Integer>> keyAndValues = map.entrySet().stream();
 ​
 //数组获取流
 String[] arr = new String[]{"Java", "JavaEE" ,"Spring Boot"};
 Stream<String> arrStream1 = Arrays.stream(arr);
 Stream<String> arrStream2 = Stream.of(arr);

常用API

方法名 说明
void forEach(Consumer<? super T> action) 逐一处理(遍历)
long count 返回流中的元素数
Stream filter(Predicate<? super T> predicate) 用于对流中的数据进行过滤
Stream limit(long maxSize) 返回此流中的元素组成的流,截取前指定参数个数的数据
Stream skip(long n) 跳过指定参数个数的数据,返回由该流的剩余元素组成的流
Stream map(Function<? super T,? extends R> mapper) 加工方法,将当前流中的 T 类型数据转换为另一种 R 类型的流
static Stream concat(Stream a, Stream b) 合并 a 和 b 两个流为一个,调用 Stream.concat(s1,s2)
Stream distinct() 返回由该流的不同元素组成的流

终结方法

终结方法:Stream 调用了终结方法,流的操作就全部终结,不能继续使用,如 foreach,count 方法等

非终结方法:每次调用完成以后返回一个新的流对象,可以继续使用,支持链式编程

 // foreach终结方法
 list.stream().filter(s -> s.startsWith("张"))
     .filter(s -> s.length() == 3).forEach(System.out::println);

收集流

收集 Stream:把 Stream 流的数据转回到集合中去

  • Stream 流:工具
  • 集合:目的

Stream 收集方法:R collect(Collector collector) 把结果收集到集合中

Collectors 方法:

  • public static <T> Collector toList():把元素收集到 List 集合中
  • public static <T> Collector toSet():把元素收集到 Set 集合中
  • public static Collector toMap(Function keyMapper,Function valueMapper):把元素收集到 Map 集合中
  • Object[] toArray():把元素收集数组中
  • public static Collector groupingBy(Function<? super T, ? extends K> classifier):分组+
目录
相关文章
|
8月前
|
Java
【Java】Stream流是什么,如何使用Stream流?
【Java】Stream流是什么,如何使用Stream流?
98 0
|
4月前
|
存储 Java API
Java——Stream流详解
Stream流是JDK 8引入的概念,用于高效处理集合或数组数据。其API支持声明式编程,操作分为中间操作和终端操作。中间操作包括过滤、映射、排序等,可链式调用;终端操作则完成数据处理,如遍历、收集等。Stream流简化了集合与数组的操作,提升了代码的简洁性
194 11
|
4月前
|
Java 数据处理
Stream流的简单使用
这篇文章介绍了Java中Stream流的基本概念和使用方法。文章解释了Stream流的三类方法:获取流、中间方法和终结方法。详细讨论了如何生成Stream流,包括从Collection体系集合、Map体系集合、数组和同种数据类型的多个数据中生成流。接着,介绍了Stream流的中间操作方法,如`filter`、`limit`、`skip`、`concat`和`distinct`。文章还讨论了Stream流的终结方法,如`forEach`和`count`,以及收集方法,如`collect`。最后,通过几个例子演示了如何使用Stream流进行数据处理和收集操作。
|
7月前
|
存储 Java API
Java——Stream流(1/2):Stream流入门、Stream流的创建(认识Stream、体验Stream流、Stream流的使用步骤、获取Stream流的方法)
Java——Stream流(1/2):Stream流入门、Stream流的创建(认识Stream、体验Stream流、Stream流的使用步骤、获取Stream流的方法)
103 0
|
8月前
|
Java
【JavaSE】Stream流
【JavaSE】Stream流
33 0
|
Java
java8的stream流
java8的stream流
66 0
|
缓存 安全 Java
Java Stream 流详解
Java Stream(流)是Java 8引入的一个强大的新特性,用于处理集合数据。它提供了一种更简洁、更灵活的方式来操作数据,可以大大提高代码的可读性和可维护性。本文将详细介绍Java Stream流的概念、用法和一些常见操作。
356 0
|
Java API
JavaSE之 I/O流(一) File
JavaSE之 I/O流(一) File
58 0
|
Java 大数据 数据处理
java的stream流
java的stream流
91 0
|
SQL Java 数据处理
java的Stream流
Java 8 引入的 Stream 流是一个非常强大且有用的概念,它提供了一种函数式编程的方式来处理集合数据。Stream 可以让我们以更简洁、更可读的方式进行数据处理和操作,极大地提高了代码的表达力和开发效率。本文将详细介绍 Java 的 Stream 流,包括其概念、特点和常用的操作方法等。
99 0