Java8:函数式编程、Stream

函数式编程:

什么是函数式接口?
        接口中有且只有一个抽象方法。当然默认方法,静态方法,私有方法可以包含。
什么是语法糖?
        更加方便,原理不变的语法。
函数式接口的定义:
        一个接口中只有一个抽象方法即可。
        例如:
@FunctionalInterface    //标识这个接口是函数式接口。
修饰符 interface 接口名称{
 public abstatic 返回值 方法名称(参数列表);  // public abstatic 可以省略。
}
lambda表达式相对于匿名内部类的优势?
     匿名内部类。(需要加载class文件)。
     lambda表达式  ()->{}  (延迟加载,并且不会加载class文件)。
     lambad表示式可以实现传递方法的效果。
lambda如何简写?
        由于lambda表达式可推导,所以参数类型是可以省略的。如果方法体中只有一行代码:后面的大括号和分号也是可以省略的。
什么是Lambda的延迟加载的特性?
        有些代码执行之后的结果不一定会使用,会造成性能的浪费。 lambda中的代码只有运行时才执行,可以利用lambda的延迟加载特性优化代码。
        将lambda表达式当作参数传递的时候,传递过去的只是lambda表达式。只有运行该表达式的时候,相应的代码才会被执行。
常用的函数式接口:
        常用的函数式接口放在:java.util.funcation包下。
        1:java.util.funcation.Supplier<T>接口
                 T get();    // 生产一个指定泛型的数据
                该接口是一个生产型的接口 。
        2:java.util.funcation.Consumer<T> 接口
                void accept(T t);   // 消费一个指定泛型的数据。
                该接口是一个消费型的接口
                Consumer接口中有些默认方法:
                        2.1:Consumer<T> andThen(Consumer<T>)  // 作用是连接两个Conusmer接口,依次消费两次。
            Consumer<String> con1;
            Consumer<String> con2;
            con1.accept("str");
            con2.accept("str");
          等同于:
            con1.andThen(con2).accept("str");
                                   上面这个链式语句,con1先消费,con2后消费。

Stream:

什么是Stream流?
    “Stream流”其实时一个集合元素操作的函数模型, 它并不是集合,也不是数据结构,其本身并不存储任何元素或者地址。
    Java中的Stream流不会存储元素,而是按需计算。
Stream能干什么?
    Stream 可以简化集合、数组操作。关注的是要做什么,不是怎么做。
为什么要用Stream流?
    因为数组集合的操作有弊端:例如:
        需求:操作集合中的数据。 代码:需要额外的遍历,然后操作数据。存在的问题:必须要额外的使用迭代器。
Stream使用案例:
// Stream流案例
List<String> nams = new ArrayList<>();
nams.add("张三");
nams.add("李四");
// 利用Stream流, 先过滤,再输出。
nams.stream().filter(n->n.length() == 3)
        .filter(n->n.contains("张"))
        .forEach(n-> System.out.println(n));
链式的调用Stream方法是在干什么?
        是在 “拼接流式模型”(比喻:构建一个处理集合的生产线,集合要依次通过各种工作站)
        就像上面代码中 filter方法只是建立模型, 最后的forEach执行时才会真正操作集合。得益于lambad的延迟加载。
Stream对集合的操作有两个基本特性:
    1、PipeLining:中间操作都会返回流本身,这样多个操作就会串成一个管道。这样做可以对操作进行优化。
    2、内部迭代:流可以直接调用遍历方法。达到遍历的效果。(不用通过迭代器)
使用Stream的一般流程为:
    1、获取一个数据源(数组或者集合)
    2、数据转换(将数据源变成Stream流)
    3、流式处理Stream流对象。(构建Stream流模型)
Stream的方法分类?
    1、延迟方法:返回类型依然是Stream类型,可以进行链式调用。
    2、终结方法:链式调用的最后一步骤。例如:forEach、count
Stream常用方法?
    1、forEach:void forEach(Consumer<? super T> action);
          用于遍历消费,Consumer是函数式消费接口。
    2、filter:stream<T> filter(Predicate<? super T> predicate)
          用于筛选元素,Predicate用于判断的函数式接口。
    3、map:<R> Stream<R> map(Funcation<? super T ,? extends R> mapper);
          用于转换元素。
    4、long count();
          终结方法,元素的数量。
    5、limit : Stream<T> limit (long maxSize)
          截取流,例如:limit(5)  截取5个元素,并返回新流。
    6:skip : Stream<T>skip (long maxSize)
           跳过后截取流,例如:skip(5) 截取[6 ~ 最后一个]形成的流。
    7:concat 静态方法,用于合并两个流。
           将两个流合并成为一个流:例如:streamC = Stream.concat(streamA , streamB)

原文地址:https://www.cnblogs.com/Xmingzi/p/12601130.html

时间: 2024-08-04 01:39:31

Java8:函数式编程、Stream的相关文章

[三]java8 函数式编程Stream 概念深入理解 Stream 运行原理 Stream设计思路

Stream的概念定义   官方文档是永远的圣经~ 表格内容来自https://docs.oracle.com/javase/8/docs/api/   Package java.util.stream  一节部分原文内容的翻译 int sum = widgets.stream() .filter(b -> b.getColor() == RED) .mapToInt(b -> b.getWeight()) .sum(); 流操作被划分为中间和终端操作,并组合成流管道. 一条Stream管道由

Java8函数式编程(二):类比Spark RDD算子的Stream流操作

1 Stream流 对集合进行迭代时,可调用其iterator方法,返回一个iterator对象,之后便可以通过该iterator对象遍历集合中的元素,这被称为外部迭代(for循环本身正是封装了其的语法糖),其示意图如下: 除此之外,还有内部迭代方法,这正是这里要说明的集合的stream()方法返回的Stream对象的一系列操作,比如,要统计一个数字列表的偶数元素个数,当使用Stream对象的操作时,如下: List<Integer> list = new ArrayList<Integ

漫漫人生路,学点Jakarta基础-Java8函数式编程

接口默认方法 Java8版本以后新增了接口的默认方法,不仅仅只能包含抽象方法,接口也可以包含若干个实例方法.在接口内定义实例方法(但是注意需要使用default关键字) 在此定义的方法并非抽象方法,而是具有特定逻辑的实例方法. 举例说明:定义接口Animal,其中包含默认方法eat(). /** * Created by zjc on 2018/4/9. */ public interface Animal { void call(); default void eat() { System.o

java8函数式编程实例

什么是函数式编程 函数式编程是java8的一大特色,也就是将函数作为一个参数传递给指定方法.别人传的要么是基本数据类型,要么就是地址引用 ,我们要穿一个“动作”. Stream 说到函数式编程,就不得不提及Stream,Stream跟我们熟知的io流可不是同一个东西,泛指可以顺序执行或者并行执行的元素序列,主要是针对集合,可以将多个函数通过“.”串起来执行,其特点如下: stream不会存储数据,只是将集合流化,比如说 声明一个stream之后,往集合里面扔东西,stream可以取到新扔到集合里

Java8函数式编程的宏观总结

1.java8优势通过将行为进行抽象,java8提供了批量处理数据的并行类库,使得代码可以在多核CPU上高效运行. 2.函数式编程的核心使用不可变值和函数,函数对一个值进行处理,映射成另一个值. 3.Lambda表达式一种紧凑的.传递行为的方式. 4. 静态类型语言java8依旧是静态类型语言,javac依旧会在编译时,对参数类型进行检查. 5.函数接口只有一个抽象方法的接口,用作lamdba表达式的类型. 6.对核心类库的改进-Stream实现机制 整个过程:一系列惰性求值方法+最后一个及早求

Java8函数式编程-包教包会系列(一)

Oracle 公司于 2014 年 3 月 18 日发布 Java 8 ,距离现在已经有很长一段时间了,Java10也在2018年 3月 21日正式发布,并且Oracle宣布Java 语言将每隔 6 个月提供一次更新.Java语言不断更新迭代,然而很多Java程序员缺没有跟上技术更新的步伐!所以写下这篇系列文章,希望可以帮助大家入门Java8!话不多说,开始发车! 前言 宝刀未老的Java 1995年Sun公司推出的Java语言,从第一个版本诞生到现在已经有二十多年的了.时间若白驹过隙,转瞬即逝

Java8函数式编程 (一) 数据流和lambda表达式

JDK 1.8中引入了函数式编程(functional programming,FP),如果您已习惯OOP,一定会感到困惑:什么是函数式编程?这样的编程模式有什么好处? 本文将通过简单的实例令读者对函数式编程有一个大体的了解. 我们知道OOP是以类为基础的,程序中必须首先抽象和定义class.那么FP创建的基础是什么?或者说在Java 8中,至少需要了解什么知识点才能实现基本的函数式编程呢? 本文将首先介绍在Java 8中使用FP所需的基本知识点: Lambda表达式 数据流 基本实例 Map<

Java8函数式编程(一):Lambda表达式类型与常用函数接口

[TOC] 1 前言 最近在看一些开源项目的源码,函数式编程风格的代码无处不在,所以得要好好学一下了. 2 Lambda表达式类型 无参数: Runnable noArguments = () -> System.out.println("Hello World!"); noArguments.run(); 一个参数: UnaryOperator<Boolean> oneArgument = x -> !x; System.out.println(oneArgu

java8 函数式编程入门官方文档中文版 java.util.stream 中文版 流处理的相关概念

前言 本文为java.util.stream 包文档的译文 极其个别部分可能为了更好理解,陈述略有改动,与原文几乎一致 原文可参考在线API文档 https://docs.oracle.com/javase/8/docs/api/ Package java.util.stream Description 一些用于支持流上函数式操作的类 ,例如在集合上的map-reduce转换.例如 int sum = widgets.stream() .filter(b -> b.getColor() == R

java8函数式编程--收集器collector

java8的stream api能很方便我们对数据进行统计分类等工作,以前我们写的很多统计数据的代码往往是循环迭代得到的,不说别人看不懂,自己的代码放久了也要重新看一段时间才能看得懂.现在,java8吸收了适合科学计算的语言的新特性,提供了stream api,让我们方便并且直观地编写统计代码成为可能. stream里有一个collect(Collector c)方法,需要传入Collector收集器这个接口.现在就说说这个接口定义的职责. public interface Collector<