本文介绍了如何产生J2SE 8的流, 包括基本类型的流IntStream, LongStream, DoubleStream 。

展现流的方法

public static <T> void show(String title, Stream<T> stream){
System.out.println("title:"+title); List<T> collect = stream.limit(10).collect(Collectors.toList());
collect.forEach(n->System.out.println(n));
System.out.println();
}

创建公共的list

ArrayList<String> arrayList = new ArrayList<>();
arrayList.add("aa");
arrayList.add("bb");
arrayList.add("cc");

1. 产生流方式一  List.stream()   List->流

Stream<String> listStream = arrayList.stream();
show("listStream", listStream);

2. 产生流方式二  List.parallelStream() 并行流,可以在多线程中执行操作  List->流

Stream<String> parallelListStream = arrayList.parallelStream();
show("parallelListStream", parallelListStream);
不想出现流被关的错误,用Supplier<T> 包装流,直接get(),多次使用不会错

Supplier<Stream<String>> arrayListSupplier = () -> arrayList.stream();
show("arrayListSupplier", arrayListSupplier.get());
show("arrayListSupplier", arrayListSupplier.get());
show("arrayListSupplier", arrayListSupplier.get());

3. 产生流方式三  Pattern方式  字符串切割->流

Stream<String> patternStream = Pattern.compile("\r\n").splitAsStream("11111\r\n22222\r\n33333\r\n6666666666666");
show("patternStream", patternStream);

4. 产生流方式四  Files方式  文件->流

Stream<String> fileStream = Files.lines(Paths.get("E:\\111.txt"),StandardCharsets.UTF_8);		//StandardCharsets.UTF_8
show("fileStream", fileStream);

5. 产生流方式五  Arrays.stream()  数组->流

Stream<String> arrayStream = Arrays.stream(new String[]{"AA","BB","CC"});
Arrays.stream(new String[]{"AA","BB","CC"},0,2); //T[] array, int startInclusive, int endExclusive 切割数组
show("arrayStream", arrayStream);

6. 产生流方式六  Stream.of()   任意对象->流

Stream.of(arrayList);
Stream<String> ofStream = Stream.of("aa","bb","cc");
show("ofStream", ofStream);

7. 产生流方式七  Stream.empty()  创建空流

Stream<Object> emptyStream = Stream.empty();
show("emptyStream", emptyStream);

8. 产生流方式八  Stream.generate()  产生无限流 无限长度的Stream,其元素的生成是通过给定的Supplier

Stream<String> generateStream1 = Stream.generate(()->"AABBCC");
show("generateStream1", generateStream1); Stream<Double> generateStream2 = Stream.generate(new Supplier<Double>() {
@Override
public Double get() {
return Math.random();
}
}); generateStream2 = Stream.generate(()->Math.random());
generateStream2 = Stream.generate(Math::random); show("generateStream2", generateStream2);

9. 产生流方式九  iterate()    接受种子+函数

Stream<BigInteger> iterateStream = Stream.iterate(BigInteger.ZERO, n->n.add(BigInteger.ONE));
show("iterateStream", iterateStream);

10. 产生流方式十  IntStream

IntStream intStream = IntStream.of(1,1,2,3,4);
show("intStream", intStream.boxed()); //boxed() 基本类型流->对象流 intStream = IntStream.range(0, 5); //[int startInclusive, int endExclusive),不包括5
show("intStream", intStream.boxed()); intStream = IntStream.rangeClosed(0, 5); //[int startInclusive, int endExclusive],包括5
show("intStream", intStream.boxed()); intStream = IntStream.generate(()->new Random().nextInt());
show("intStream", intStream.boxed()); intStream = IntStream.iterate(0, n->n+8);
show("intStream", intStream.boxed()); IntStream mapToIntStream = arrayList.stream().mapToInt(String::length); //mapToInt 将对象流->基本类型流
show("mapToIntStream", mapToIntStream.boxed());

11. 产生流方式十一  LongStream

LongStream longStream = LongStream.of(1,1,2,3,4);
show("longStream", longStream.boxed()); //boxed() 基本类型流->对象流 longStream = LongStream.range(0, 5); //[int startInclusive, int endExclusive),不包括5
show("longStream", longStream.boxed()); longStream = LongStream.rangeClosed(0, 5); //[int startInclusive, int endExclusive],包括5
show("longStream", longStream.boxed()); longStream = LongStream.generate(()->new Random().nextLong());
show("longStream", longStream.boxed()); longStream = LongStream.iterate(0, n->n+8);
show("longStream", longStream.boxed()); LongStream mapToLongStream = arrayList.stream().mapToLong(x->(long)x.length()); //mapToLong 将对象流->基本类型流
show("mapToLongStream", mapToLongStream.boxed());

12. 产生流方式十二  DoubleStream

DoubleStream doubleStream = DoubleStream.of(1.1,1.2,1.3,2.1,2.2);
show("doubleStream", doubleStream.boxed()); doubleStream = DoubleStream.generate(Math::random);
show("doubleStream", doubleStream.boxed()); doubleStream = DoubleStream.iterate(1.1, n->n+1.1);
show("doubleStream", doubleStream.boxed()); DoubleStream mapToDoubleStream = arrayList.stream().mapToDouble(x->(double)x.length()); //mapToDouble 将对象流->基本类型流
show("mapToDoubleStream", mapToDoubleStream.boxed());


13. 对应的,创建short,char,byte,boolean,float流

Stream<Boolean> booleanStream = Arrays.stream(new Boolean[]{true,false,false,true});
show("booleanStream", booleanStream);

14.  流操作, 不要修改流操作中间引出的集合的值

//不在流中修改arrayList,不要紧
Stream<String> stream = arrayList.stream();
arrayList.add("added stream");
System.out.println(stream.count()); //在流中修改arrayList,会 java.util.ConcurrentModificationException
//arrayList.stream().forEach(s->arrayList.remove(s));

15. 并行流

使用并行流的条件:
1).操作可以以任意顺序执行, 顺序执行结果和不顺序执行的结果相同
2).操作可以分开执行,并行执行
//生成并行流的两种方式
Stream<String> parallelStream = arrayList.parallelStream();
parallelStream = arrayList.stream().parallel(); Map<Integer, Long> parallelStreamResult = parallelStream.filter(w->w.length()>1).collect(Collectors.groupingBy(String::length, Collectors.counting()));
parallelStreamResult.entrySet().forEach((n)->System.out.println(n.getKey()+" , counting:"+n.getValue())); //unordered表示对排序不感兴趣, 打乱顺序
arrayList.parallelStream().limit(2).forEach((n)->System.out.println(n));
System.out.println();
arrayList.parallelStream().unordered().limit(2).forEach((n)->System.out.println(n));





J2SE 8的流库 --- 生成流的更多相关文章

  1. J2SE 8的流库 --- 转换流, 得到的还是流

    流的转换, 按照条件过滤/映射/摊平/截取/丢弃/连接/去重/排序. 辅助方法 public static int myCompare(String x, String y) { if(x.lengt ...

  2. J2SE 8的流库 --- 基本类型流的使用

    展现流的方法 public static <T> void show(String title, Stream<T> stream){ System.out.println(& ...

  3. Java SE 8 流库

    1. 流的作用 通过使用流,说明想要完成什么任务,而不是说明如何去实现它,将操作的调度留给具体实现去解决: 实例:假如我们想要计算某个属性的平均值,那么我们就可以指定数据源和属性,然后,流库就可以对计 ...

  4. Java SE 8 流库(一)

    1. 流的作用 通过使用流,说明想要完成什么任务,而不是说明如何去实现它,将操作的调度留给具体实现去解决: 实例:假如我们想要计算某个属性的平均值,那么我们就可以指定数据源和属性,然后,流库就可以对计 ...

  5. Java SE 8 的流库学习笔记

    前言:流提供了一种让我们可以在比集合更高的概念级别上指定计算的数据视图.如: //使用foreach迭代 long count = 0; for (String w : words) { if (w. ...

  6. Java高级特性1_流库_初体验

    Java高级特性流库_初体验 面对结果编程 在编程里, 有两种编程方式, 一种是面对过程编程, 一种是面对结果编程. 两者区别如下 面向过程编程 面向过程编程需要编程程序让程序依次执行得到自己想要的结 ...

  7. 用内存流 文件流 资源生成客户端(Delphi开源)

    正文:很多木马生成器就是用的内存流和文件流生成客户端的,废话不多说了,代码如下: unit Main; interface usesWindows, Messages, SysUtils, Varia ...

  8. Java SE 8 流库(二)

    1.3. filter,map,flatMAP方法 流的转换会产生一个新流,它的元素派生出自另一个流中的元素: Stream<T> filter(Predicate<? super ...

  9. 第01章-Java SE8的流库

    从迭代到流的操作 流表面上看起来和集合很类似,都可以让我们转换和获取数据,但是它们之间存在着显著的差异 流并不存储其元素,这些元素可能存储在底层的集合中,或者是按需生成的 流的操作不会修改其数据源 流 ...

随机推荐

  1. QQ在开发中的应用

    1 截图 2 快捷回复 1svn更新 2美术资源替换 3后端服务器模块确认 4开会吧 5策划更新

  2. PAT 乙级 1029 旧键盘(20) C++版

    1029. 旧键盘(20) 时间限制 200 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 旧键盘上坏了几个键,于是在敲一段文字的 ...

  3. scroll家族属性

    上一篇主要分析了一下offset家族属性,本篇文章则主要是来分析一下scroll家族属性. 首先,scroll家族包括4个属性: 网页正文宽度:document.body.scrollWidth; 网 ...

  4. Spring4.0之四:Meta Annotation(元注解)

    Spring框架自2.0开始添加注解的支持,之后的每个版本都增加了更多的注解支持.注解为依赖注入,AOP(如事务)提供了更强大和简便的方式.这也导致你要是用一个相同的注解到许多不同的类中去.这篇文章介 ...

  5. Java-Runoob-高级教程-实例-方法:10. Java 实例 – 标签(Label)

    ylbtech-Java-Runoob-高级教程-实例-方法:10. Java 实例 – 标签(Label) 1.返回顶部 1. Java 实例 - 标签(Label)  Java 实例 Java 中 ...

  6. 不同AI学科之间的联系

    这里只是引用deep learning中的关于不同AI学科之间联系的图示,如果想具体了解相关知识,深入学习深度学习,可以参考网站:http://www.deeplearningbook.org 下面是 ...

  7. spring中关于<context:component-scan>的使用说明(转)

    https://blog.csdn.net/liuxingsiye/article/details/52171508 通常情况下我们在创建spring项目的时候在xml配置文件中都会配置这个表情,配置 ...

  8. [UE4]UMG和关卡坐标变换、旋转小地图

    一.优化上一节的蓝图,新建一个函数addFlagToCanvas(动态添加图标到Canvas) 二. 分析地图坐标系和UMG坐标系 要根据实际情况分析关卡坐标系. UserWidget中的坐标系 三. ...

  9. 00011 - find中的-print0和xargs中-0的奥妙

    默认情况下, find 每输出一个文件名, 后面都会接着输出一个换行符 ('\n'), 因此我们看到的 find 的输出都是一行一行的: [bash-4.1.5] ; ls -l total 0 -r ...

  10. Java关键字final、static使用总结(转)

    原文链接:Java关键字final, static一些要点 1. final   final类不能被继承,没有子类,final类中的方法默认是final的 final方法不能被子类的方法复盖,但可以被 ...