Java8函数式编程的宏观总结

1.java8优势
通过将行为进行抽象,java8提供了批量处理数据的并行类库,使得代码可以在多核CPU上高效运行。

2.函数式编程的核心
使用不可变值和函数,函数对一个值进行处理,映射成另一个值。

3.Lambda表达式
一种紧凑的、传递行为的方式。

4. 静态类型语言
java8依旧是静态类型语言,javac依旧会在编译时,对参数类型进行检查。

5.函数接口
只有一个抽象方法的接口,用作lamdba表达式的类型。

6.对核心类库的改进-Stream
实现机制
整个过程:一系列惰性求值方法+最后一个及早求值方法
常用流操作

collect
及早求值的方法,用于生成list,set,map。
map
将一个流中的值转化为一个新的流,对应的业务逻辑是:有一个函数需要将一种类型的值转为另一种类型。
filter
遍历数据并检查其中的元素,过滤掉不符合条件的元素。接受一个Predicate接口
flatmap
可用Stream替换值,然后将多个Stream连接成一个Stream
例如:List together=Stream.of(list1,list2,…,listn).flatMap(num->num.stream()).collect(Collectors.toList());
max和min
参数:参数为排序指标
格式:xx.stream().max(Comparator.comparing(…)).get();
reduce
从一组值生成一个值
例如count(),sum()等
使用方法有两种形式
有初始值
无初始值
返回对象:Optional对象
如果code想要并行化,则reduce操作有2个限制
初值必须为组合函数的恒等值
组合操作必须符合结合律
Stream迭代的优势

利用Stream进行迭代,使得迭代过程从外部迭代 转为 内部迭代。
外部迭代缺点:
本质上,属于串行化操作
7. 对核心类库的改进-集合类API
形式上:引入default方法和接口的static方法
基本类型的改变:
只包括:Integer,Long,Double共计3种,因为这3种在数值计算中使用的最多。
Stream类的某些方法对基本类型和装箱类型进行了区分,目的是减少装箱拆箱的性能开销。
default方法出现的意义
实现了库接口的自定义类,在库接口添加新方法时,可以在不改变客户端自定义类的情况下,使得自定义类正常运行。因为新添加的方法类型为default,这样自定义的类虽然没有实现这个接口方法,但是自动拥有了这个方法,因为库接口提供了这个方法的默认实现。
Optional新增数据类型
功能:
用于替换null
使用Optional的目的
Optional对象鼓励程序员适时检查变量是否为空。
它将一个类的API中可能为空的值文档化,更适合阅读。
8.数据并行化
数据并行化的必要性
多核CPU的出现,需要通过并行化的code来提升现有代码的计算能力,而不再依赖提升CPU的时钟频率。
阿姆达尔定律
预测了搭载多核CPU的机器提升速度的理论最大值。例如,如果将一段完全串行化的code,一半改为并行化处理,则CPU>=2的所有情况中,理论上最大速度都是原来的2倍。因此,可以得出结论,问题的求解时间,完全取决于:问题可以被分解为几个部分
影响并行流性能的5个因素
数据大小。因为涉及到数据分解、合并的开销。
源数据结构。因为这涉及数据分割的开销。
装箱。
核的数量。这里核的数量是指:运行时,机器能使用的核的数量,而不是机器上有多少核。
单元处理开销。单元处理开销时间越长,并行操作带来的性能提升越明显。
核心类库的通用数据结构分类
分类标准
长度是否确定,结构是否复杂两方面考虑。
性能好(长度确定,线性结构)
如ArrayList,数组,Intstream.range等。支持随机读取,易分解。
性能一般(结构复杂,tree/hash类型)
如HashSet,TreeSet等,不易公平分解。
性能差(长度不定)
如LinkedList,分解时间复杂度为:O(N)。
java8对数组新增的并行化操作方法
Arrays.parallelPrefix,计算数组的和
Arrays.parallelSetAll,更新数组元素
Arrays.parallelSort,对数组元素排序

原文地址:https://www.cnblogs.com/zhuyeshen/p/11757938.html

时间: 2024-12-10 14:12:34

Java8函数式编程的宏观总结的相关文章

漫漫人生路,学点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函数式编程-包教包会系列(一)

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函数式编程(二):类比Spark RDD算子的Stream流操作

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

[三]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函数式编程

在Java8的 java.util.function中包含以下几个接口 1.Function,先上源码 /* * Copyright (c) 2010, 2013, Oracle and/or its affiliates. All rights reserved. * ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms. */ package java.util.function; import java.util.

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

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