实战Java高并发程序设计笔记第六章

2019-12-11  本文已影响0人  MisterDo

Java 8的函数式编程简介

函数作为一等公民

无副作用

什么是函数的副作用?

函数的副作用是指函数在调用过程中,除了给出了返回值外,还修改了函数外部的状态
显式函数与隐式函数
显式函数值函数与外界交换数据的唯一渠道就是参数和返回值,显式函数不会去读取或修改函数的外部状态;
隐式函数除了参数和返回值外,还会读取外部信息,或者可能修改外部信息

申明式的

申明式与命令式编程?

函数式编程就是申明式的,不需要提供明确的指令操作,所有的细节指令将会更好地被程序所封装,要做的就是提出要求,申明用意;
命令式的程序喜欢大量使用可变对象和指令,要求程序执行。

不变的对象

易于并行

对象不变,不用担心线程安全问题

更少的代码

函数式编程基础

FunctionalInterface注释

什么是函数接口?

只定义了单一抽象方法的接口
例子:

@FunctionalInterface
public static interface IntHandler{
  void handle(int i);
}

接口默认方法

lambda表达式

什么是lambda表达式?

即匿名函数,是一段没有函数名的函数体,可以作为参数直接传递给相关的调用者

方法引用

什么是方法引用?

Java8中提出的用来简化lambda表达式的一种手段。它通过类名和方法名来定位一个静态方法或者实例方法
方法引用分为以下几种:

一步一步走入函数式编程

并行流与并行排序

从集合得到并行流

并行排序

增强的Future:CompletableFuture

完了就通知我

异步执行任务

流式调用

上一篇 下一篇

猜你喜欢

热点阅读