Java8 Stream

描述:Java8 开始,Collection集合中新增了两个和流有关的方法,分别Stream同步流和parallelStream异步流,通过lambda表达对集合实现高效的处理

常用操作

// 从0开始,依次递增2进行遍历,保留前2位后进行截流并输出
Stream<Integer> intStream = Stream.iterate(0, x -> x + 2);
intStream.limit(2).forEach(item -> { System.out.println(item); });

// 生成布尔流,保留前2位后进行截流并输出
Stream<Boolean> booleanStream = Stream.generate(() -> new Random().nextBoolean());
booleanStream.limit(2).forEach(item -> { System.out.println(item); });

// 生成整型流,保留前2位后进行截流并输出
Stream<Integer> integerStream = Stream.generate(() -> new Random().nextInt(10));
integerStream.limit(2).forEach(item -> { System.out.println(item); });

// 生成Double流,保留前2位后进行截流并输出
Stream<Double> doubleStream = Stream.generate(() -> new Random().nextDouble());
doubleStream.limit(2).forEach(System.out::println);
String[] stringArray= "1,2,3,4,5".split(","); // new String[]{1, 1, 2, 3, 4, 5}
List<String> list = Arrays.stream(result).collect(Collectors.toList());
// String str = StringUtils.join(list, ",");
// String str = String.join(",", list);
Stream<String> integerStream = Arrays.stream(result);
integerStream
        .distinct() // 去重
        .sorted((o1, o2) -> o2 - o1) // 排序
        .filter(item -> item % 2 == 0) // 过滤
        .map(item -> item += 1) // 数据操作
        .forEach(item -> System.out.println(item)); // 遍历
// 将数组转发成列表
List<Integer> integerList = integerStream.collect(Collectors.toList());
  • 并行流(默认串行流)
List<Student> studentList = new ArrayList<>();
studentList.add(new Student("张三", 20));
studentList.add(new Student("李四", 22));
studentList.add(new Student("王五", 24));
studentList.add(new Student("赵六", 26));
studentList.parallelStream().distinct().forEach(item -> {
	System.out.println(MessageFormat.format("当前线程名称:{0},待处理用户数据:{1}", Thread.currentThread().getName(), 		item.getName()));
        });

当前线程名称:ForkJoinPool.commonPool-worker-2,待处理用户数据:王五
当前线程名称:ForkJoinPool.commonPool-worker-4,待处理用户数据:张三
当前线程名称:ForkJoinPool.commonPool-worker-9,待处理用户数据:李四
当前线程名称:ForkJoinPool.commonPool-worker-11,待处理用户数据:赵六

统计

@Data
class DemoVo {
    /** 班号 */
    private Integer classNum;
    /** 学号 */
    private Integer stuNum;
    /** 语文得分 */
    private Double ywScore;
    /** 数学得分 */
    private Double sxScore;

    public DemoVo(Integer classNum, Integer stuNum, Double ywScore, Double sxScore) {
        this.classNum = classNum;
        this.stuNum = stuNum;
        this.ywScore = ywScore;
        this.sxScore = sxScore;
    }
}
DemoVo demoVo1 = new DemoVo(310111, 31011101, 51.00, 50.00);
DemoVo demoVo2 = new DemoVo(310111, 31011102, 91.00, 50.00);
DemoVo demoVo3 = new DemoVo(310112, 31011201, 53.00, 50.00);
DemoVo demoVo4 = new DemoVo(310112, 31011202, 93.00, 50.00);

List<DemoVo> demoVoList = new ArrayList<>();
demoVoList.add(demoVo1);
demoVoList.add(demoVo2);
demoVoList.add(demoVo3);
demoVoList.add(demoVo4);

// 获取班号
List<Integer> classNumList = demoVoList.stream().map(DemoVo::getClassNum).distinct().collect(Collectors.toList());
Set<Integer> classNumSet = demoVoList.stream().map(DemoVo::getClassNum).collect(Collectors.toSet());
// 聚合操作
// 语文成绩的最高分
Double ywScoreMax = demoVoList.stream().map(DemoVo::getYwScore).max(Double::compare).get();
// 语文成绩的最低分
Double ywScoreMin = demoVoList.stream().map(DemoVo::getYwScore).min(Double::compare).get();
// 语文成绩的平均分
Double avgYwScore = demoVoList.stream().collect(Collectors.averagingDouble(DemoVo::getYwScore));
// 语文成绩的总分
Double allYwScore = demoVoList.stream().mapToDouble(DemoVo::getYwScore).sum();
// 数据总数 + 求和 + 最小值 + 最大值
DoubleSummaryStatistics statistics = demoVoList.stream().collect(Collectors.summarizingDouble(DemoVo::getYwScore));

// 分组(班级)
Map<Integer, List<DemoVo>> demoVoListByClassNum = demoVoList.stream().collect(Collectors.groupingBy(DemoVo::getClassNum));
// 分组(班级和学号)
Map<String, List<DemoVo>> demoVoListByClassNumAndStuNum = demoVoList.stream().collect(Collectors.groupingBy(item -> MessageFormat.format("{0},{1}",item.getClassNum(),item.getStuNum()));

// 分区(语文成绩及格)
Map<Boolean, List<DemoVo>> demoVoListByJg = demoVoList.stream().collect(Collectors.partitioningBy(v -> v.getYwScore() > 60));
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Java 8引入了Stream API,它是一种处理集合数据的新方式。Stream API提供了一种式操作的方式,可以对集合进行过滤、映射、排序、聚合等操作,使得代码更加简洁、易读和高效。 Stream是一个来自数据源的元素队列并支持聚合操作。它可以是集合、数组、I/O channel、产生器等。Stream操作可以顺序执行,也可以并行执行。 Java 8 Stream API的特点包括: 1. 延迟执行:Stream操作通常是延迟执行的,只有在终止操作时才会触发实际的计算。 2. 内部迭代:Stream API使用内部迭代的方式,不需要显式地编写循环,使得代码更加简洁。 3. 函数式编程:Stream API支持函数式编程风格,可以通过Lambda表达式来定义操作。 4. 并行处理:Stream API提供了并行处理的能力,可以充分利用多核处理器的优势,提高处理速度。 使用Stream API可以通过一系列的中间操作和终止操作来对集合进行处理。中间操作包括过滤、映射、排序等操作,终止操作包括聚合、收集、遍历等操作。 下面是一些常用的Stream操作方法: 1. filter(Predicate<T> predicate):根据指定条件过滤元素。 2. map(Function<T, R> mapper):将元素进行映射转换。 3. sorted(Comparator<T> comparator):对元素进行排序。 4. distinct():去除重复的元素。 5. limit(long maxSize):限制元素的数量。 6. skip(long n):跳过指定数量的元素。 7. forEach(Consumer<T> action):对每个元素执行指定操作。 8. collect(Collector<T, A, R> collector):将元素收集到集合中。 9. reduce(BinaryOperator<T> accumulator):对元素进行归约操作。 10. parallel():启用并行处理。 以上只是Stream API的一部分常用操作,还有更多的操作方法可以根据具体需求使用。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

大能嘚吧嘚

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

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

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

打赏作者

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

抵扣说明:

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

余额充值