Java8新特性(三)------Stream

原创 2016年05月30日 16:03:18

 Ø  基础讲解

  在java8中Stream被定义为泛型接口,这个接口代表的是数据流,但是Stream并不是一个数据结构,不直接进行数据的存储。Stream主要是通过管道来操作数据。

  Stream 不是集合元素,它不是数据结构并不保存数据,它是有关算法和计算的,它更像一个高级版本的 Iterator。原始版本的Iterator,用户只能显式地一个一个遍历元素并对其执行某些操作;高级版本的 Stream,用户只要给出需要对其包含的元素执行什么操作,比如 “过滤掉长度大于 10 的字符串”、“获取每个字符串的首字母”等,Stream会隐式地在内部进行遍历,做出相应的数据转换。

  而和迭代器又不同的是,Stream可以并行化操作,迭代器只能命令式地、串行化操作。顾名思义,当使用串行方式去遍历时,每个 item 读完后再读下一个 item。而使用并行去遍历时,数据会被分成多个段,其中每一个都在不同的线程中处理,然后将结果一起输出。Stream 的并行操作依赖于 Java7 中引入的 Fork/Join 框架(JSR166y)来拆分任务和加速处理过程。

  使用Stream执行完毕的对象,通常包括三个处理流程:

  获取一个数据源(source)→数据转换→执行操作获取想要的结果,每次转换原有 Stream 对象不改变,返回一个新的 Stream 对象

 Ø  示例讲解

public class TestStream {
    public static void main( String[] args ) {
        List<Integer> lis = Arrays.asList(4, 3, 5, 6, 8, 10,7);
//   1、 取出大于5的元素
    List<Integer> result=lis.stream().filter(e->e>5).collect(Collectors.toList());
//        取出集合并且遍历
        result.forEach(e-> System.out.println(e+""));


        //2、对取出的结果进行排序

        result=result.stream().sorted().collect(Collectors.toList());
        result.forEach(e-> System.out.println(e+""));

//      /3、 跳过前三个对象,并且对后面的元素进行排序【stream可以无限的链式进行操作,下面的就是使用了skip和sorted】
     List<Integer> liSkip=lis.stream().skip(3).sorted().collect(Collectors.toList());
        liSkip.forEach(e-> System.out.println(e+""));
//4、map操作,取出集合中某一个属性的集合【student只有id和name两个属性】
        List<Student> stus=Arrays.asList(new Student(1,"stu1"),new Student(2,"stu2"),new Student(3,"stu3"));

//        只是取出所有元素的id属性

        List<Integer> ids=stus.stream().map(e->e.getId()).collect(Collectors.toList());
        ids.forEach(e-> System.out.println(e+""));  //输出结果1,2,3

//        6、map集合的lambda表达式
        Map<Integer,String> map=new HashMap<>();
        map.put(1,"str1");
        map.put(2,"str2");
        map.put(3,"str3");

        map.computeIfPresent(3,(k,v)->v+k);
        System.out.println(map);

    }

  Stream的各种操作以及输出都是结合了lambda表达式的

  以上这几个实例讲解了Stream操作的,当然还有其他的,这个需要我们在以后的应用中多多实践了
版权声明:本文为博主原创文章,未经博主允许不得转载。

java8新特性(三):Stream流的概念

流就是让程序员可以用声明式编程来处理集合数据的java接口,简单来说你可以把它看成是遍历数据集的高级迭代器,可以透明的并行处理,所以不需要程序员再写任何多线程代码了。 java7 之前(指令式编程...

Java 8新特性:全新的Stream API (三) 转载整理

Java 8引入了全新的Stream API。这里的Stream和I/O流不同,它更像具有Iterable的集合类,但行为和集合类又有所不同。 Stream API引入的目的在于弥补Java函数式编...

Java8新特性Stream API与Lambda表达式详解(1)

简单说,对 Stream 的使用就是实现一个 filter-map-reduce 过程,产生一个最终结果,或者导致一个副作用(side effect)。 当我们使用一个流的时候,通常包括三个基本步骤:...
  • chs0113
  • chs0113
  • 2016年05月02日 22:16
  • 5728

java8 新特性 - Stream

java8 stream

Java 8新特性:全新的Stream API

Java 8引入了全新的Stream API。这里的Stream和I/O流不同,它更像具有Iterable的集合类,但行为和集合类又有所不同。 Stream API引入的目的在于弥补Java函数式编程...
  • qfycc92
  • qfycc92
  • 2015年02月02日 14:04
  • 346

Java 8新特性:Stream API

今天给大家介绍一下Java 8的新特性:Stream API,它能够应用在一组元素上一次执行的操作序列,在某些场景下极大简化我们的代码。 Stream API是Java8类库的核心,它能够应用在一组...

java8新特性 (λ、stream 与 默认接口方法)

1.lambda λ表达式本质上是一个匿名方法,用来方便地实现函数接口。也就是说,λ表达式主要用于替换以前广泛使用的内部匿名类。  让我们来看下面这个例子:     public int add(in...

java8新特性(六):Stream多线程并行数据处理

将一个顺序执行的流转变成一个并发的流只要调用 parallel()方法 public static long parallelSum(long n){     return Stream.iter...

java 8 新特性(4.Stream API)

为什么需要 Stream Stream 作为 Java 8 的一大亮点,它与 java.io 包里的 InputStream 和 OutputStream 是完全不同的概念。它也不同于 StAX 对...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Java8新特性(三)------Stream
举报原因:
原因补充:

(最多只允许输入30个字)