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

Java 8的函数式编程简介

函数作为一等公民

  • 将函数作为参数传递给另外一个函数
  • 函数可以作为另外一个函数的返回值

无副作用

什么是函数的副作用?

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

申明式的

申明式与命令式编程?

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

  • 命令式:
    public static void imperative(){
      int[] iArr = {1,3,2,4,9,8};
      for(int i=0;i
  • 申明式:
    public static void imperative(){
      int[] iArr = {1,3,2,4,9,8};
      Arrays.stream(iArr).forEach(System.out::println);
    }
    

不变的对象

  • 在使用函数式编程时,几乎所有的对象都拒绝被修改

易于并行

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

更少的代码

函数式编程基础

FunctionalInterface注释

什么是函数接口?

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

@FunctionalInterface
public static interface IntHandler{
  void handle(int i);
}
  • @FunctionalInterface表明IntHandler是一个函数式接口
  • 函数式接口只能有一个抽象方法,而不是只能有一个方法
    • 接口运行存在实例方法(接口默认方法)
    • 任何被java.lang.Object实现的方法,都不能被视为抽象方法

接口默认方法

  • default
  • 多继承产生的问题->实现接口默认方法

lambda表达式

什么是lambda表达式?

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

  • lambda表达引入的外部变量必须final的,若不是,则隐式转为final的

方法引用

什么是方法引用?

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

  • 静态方法引用 ClassName::methodName
  • 实例上的实例方法引用 instanceReference::methodName
  • 超类上的实例方法引用 super::methodName
  • 类型上的实例方法引用 ClassName::methodName
  • 构造方法引用
    Class::new
  • 数组构造方法引用
    TypeName[]::new

一步一步走入函数式编程

并行流与并行排序

从集合得到并行流

并行排序

增强的Future:CompletableFuture

完了就通知我

异步执行任务

流式调用

你可能感兴趣的:(实战Java高并发程序设计笔记第六章)