Stream 的基本操作


从 jdk1.8 开始,由于进入到了大数据的时代,所以在类集里面也支持有数据的流式分析处理操作,在 Java 中提供了一个 Stream 的接口,同时在 Collection 接口里面也提供有为此接口实例化的方法:

  • 获取 Stream 接口对象:default Stream< E > stream()

Stream 的基础操作

Stream 的主要功能是进行数据的分析处理,同时主要是针对于集合中的数据进行分析操作

举例:(输出元素个数)

package com.java.springtest.testdemo;

import java.util.*;
import java.util.stream.Stream;

/**
 * @author Woo_home
 * @create by 2020/1/31
 */

public class Demo {
    public static void main(String[] args) {
        List<String> all = new ArrayList<>();
        Collections.addAll(all,"Java","JavaScript","Python","Ruby","Go");
        Stream<String> stream = all.stream(); // 可以获取 Stream 的接口对象
        System.out.println(stream.count());   // 输出元素的个数
    }
}

在这里插入图片描述

基本的 Stream 操作

package com.java.springtest.testdemo;

import java.util.*;
import java.util.stream.Stream;

/**
 * @author Woo_home
 * @create by 2020/1/31
 */

public class Demo {
    public static void main(String[] args) {
        List<String> all = new ArrayList<>();
        Collections.addAll(all,"Java","JavaScript","Python","Ruby","Go");
        Stream<String> stream = all.stream(); // 可以获取 Stream 的接口对象
        // 要求将每一个元素的字母变为小写的字母,然后判断字母 j 是否存在
        System.out.println(stream.filter((ele) -> ele.toLowerCase().contains("j")).count());
    }
}

输出:

举例:(数据采集)

但是以上的程序只是实现了一些最基础的数据的个数的统计,而更多情况下我们可能需要的是获取里面的满足条件的数据内容,所以此时可以实现数据采集的操作

package com.java.springtest.testdemo;

import java.util.*;
import java.util.stream.Collectors;
import java.util.stream.Stream;

/**
 * @author Woo_home
 * @create by 2020/1/31
 */

public class Demo {
    public static void main(String[] args) {
        List<String> all = new ArrayList<>();
        Collections.addAll(all,"Java","JavaScript","Python","Ruby","Go");
        Stream<String> stream = all.stream(); // 可以获取 Stream 的接口对象
        // 要求将每一个元素的字母变为小写字母,然后判断字母 j 是否存在,将满足条件的数据收集起来转为 list 集合
        List<String> result = stream.filter((ele) -> ele.toLowerCase().contains("j")).collect(Collectors.toList());
        System.out.println(result);
    }
}

输出:
在这里插入图片描述

举例:(观察分页)

在 Stream 数据流处理的过程之中还允许进行数据的分页处理,提供有两个方法:

  • 设置取出的最大数据量:Stream< T > limit(long maxSize)
  • 跳过指定数据量:Stream< T > skip(long n)
package com.java.springtest.testdemo;

import java.util.*;
import java.util.stream.Collectors;
import java.util.stream.Stream;

/**
 * @author Woo_home
 * @create by 2020/1/31
 */

public class Demo {
    public static void main(String[] args) {
        List<String> all = new ArrayList<>();
        Collections.addAll(all,"Java","JavaScript","JSP","JSON","Python","Ruby","Go");
        Stream<String> stream = all.stream(); // 可以获取 Stream 的接口对象
        // 要求将每一个元素的字母变为小写字母,然后判断字母 j 是否存在,将满足条件的数据收集起来转为 list 集合
        List<String> result = stream.filter((ele) -> ele.toLowerCase().contains("j")).skip(2).limit(2).collect(Collectors.toList());
        System.out.println(result);
    }
}

输出:
在这里插入图片描述
Stream 的操作主要是利用自身的特点实现数据分析处理操作

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值