Stream流技术

Stream(流)是一个来自数据源的元素队列并支持聚合操作

元素是特定类型的对象,形成一个队列。 Java中的Stream并不会存储元素,而是按需计算。

数据源 流的来源。 可以是集合,数组,I/O channel, 产生器generator 等。

聚合操作 类似SQL语句一样的操作, 比如filter, map, reduce, find, match, sorted等。 和以前的Collection操作不同, Stream操作还有两个基础的特征:

Pipelining: 中间操作都会返回流对象本身。 这样多个操作可以串联成一个管道, 如同流式风 格(fluent style)。 这样做可以对操作进行优化, 比如延迟执行(laziness)和短路( shortcircuiting)。

内部迭代: 以前对集合遍历都是通过Iterator或者For-Each的方式, 显式的在集合外部进行迭 代, 这叫做外部迭代。 Stream提供了内部迭代的方式, 通过访问者模式(Visitor)实现。

public static void main(String[] args) {
IntStream is = IntStream.of(10, 20, 30, 40, 50);
is.forEach(System.out::println);
System.out.println(IntStream.rangeClosed(1, 100).sum());
System.out.println(IntStream.generate(() -> 5).limit(3).count());
IntStream i2 = IntStream.generate(() -> {
Random rand = new Random();
return rand.nextInt(100) + 1;
}).limit(10);
IntConsumer ic = (a) -> {
System.out.printf("%d ", a);
};
i2.forEach(ic);
System.out.println();
//1 3 5 7 9
IntStream.iterate(1, a -> a + 2).limit(5).forEach(ic);
//IntStream.iterate(2, a -> a +
2).limit(15).forEach(System.out::println);
System.out.println();
//2 4 6 ..
IntStream.iterate(2, a -> a + 2).skip(3).limit(15).forEach(ic);
// IntStream 转换为 List<Integer>
List<Integer> list = new ArrayList<>();
list.add(1);
list.add(1);
list.add(1);
System.out.println();
// list.stream().forEach(System.out::println); //Stream<Integer>
//Stream<Integer> ss = list.stream();
IntStream ii2 = list.stream().mapToInt(i -> i);
//Stream<Integer> sa = ii2.boxed();
List<Integer> lis = ii2.boxed().collect(Collectors.toList());
System.out.println(lis.size());
// IntStream.iterate(1, a->a+2).limit(5).col
List<String> as = List.of("java","php");
Stream<String> sss = as.stream();
}

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值