第一章:为什么要关注Java8

image.png

  • 总结:

Stream API
向方法传递代码的技巧
接口中的默认方法
Lamba表达式让代码更加简洁

1.1 Java怎么还在变

image.png

1.1.1 java在编程语言生态系统中的位置

image.png

  • 故事:

image.png
image.png

1.1.2 流处理

image.png

1.1.3 用行为参数化把代码传递给方法

image.png

1.1.4 并行与共享的可变数据

image.png

1.1.5 Java需要演变

image.png

1.2 Java中的函数

image.png

1.2.1 方法和Lambda作为一等公民

image.png

  • Lambda——-匿名函数

image.png

1.2.2 传递代码:一个例子

image.png
image.png

1.2.3 从传递方法到Lambda

image.png

1.3 流

image.png
image.png

  • 多线程并非易事

image.png

1.4 默认方法

image.png

1.5 来自函数式编程的其他好思想

image.png

1.6 小结

image.png

第二章: 通过行为参数化传递代码

image.png

2.1 应对不断变化的需求

image.png

2.1.1 初试牛刀:筛选绿苹果

image.png

2.1.3 第三次尝试:对你能想到的每一个属性做筛选

image.png

2.2 行为参数化

image.png
第四次尝试:根据抽象条件筛选
image.png
image.png

2.3 对付啰嗦

image.png

2.3.2 第五次尝试:使用匿名类

image.png

2.3.3 第六次尝试:使用Lambda表达式

image.png

2.3.4 第七次尝试:将List类型抽象化

image.png

2.4 真实的例子:

image.png

2.4.1 用comparator来排序

image.png

2.4.2 用Runnable执行代码块

image.png

2.4.3 GUI事件处理

image.png

第三章: Lambda表达式

3.1 Lambda管中窥豹

image.png
image.png
image.png
image.png

3.2.1 函数式接口

image.png
image.png

3.2.2 函数描述符

image.png
image.png

3.3 把Lambda付诸实践:环绕执行模式

image.png

3.3.1 第1步:记得行为参数化

image.png

3.2.2 第2步:使用函数式接口来传递行为

image.png

3.3.4 第4步:传递Lambda

image.png

3.4 使用函数式接口

image.png

3.4.1 Predicate

image.png
image.png

3.4.2 consumer

image.png

3.4.3 Function

image.png
image.png

3.5 类型检查、类型推断以及限制

image.png

3.5.1 类型检查

image.png

3.5.2 同样的Lambda,不同的函数式接口

image.png

3.5.3 类型推断

image.png

3.5.4 使用局部变量

image.png

3.6 方法引用

image.png

3.6.1 管中窥豹

image.png
image.png
image.png

3.7 Lambda和方法引用实战

image.png

3.7.1 第一步:传递代码

image.png

3.7.2 第二步:使用匿名类

image.png

3.7.3 第三步:使用Lambda表达式

image.png
image.png

3.8.1 比较器复合

image.png
image.png

3.8.3 函数复合

image.png
image.png
image.png

3.10 小结:

image.png

第二部分: 函数式数据处理

image.png

第四章:引入流

image.png

4.1 流是什么

image.png
image.png
image.png

4.2 流简介

image.png

4.3 流与集合

image.png

4.3.1 只能遍历一次

image.png

4.3.2 外部迭代与内部迭代

image.png
image.png

4.4.1 中间操作

image.png

4.4.2 终端操作

image.png

4.4.3 使用流

image.png

4.5 小结:

image.png

第五章: 使用流

image.png

5.1 筛选和切片

5.1.1 用谓语筛选

image.png

5.1.2 筛选各异的元素

image.png

5.1.3 截短流

image.png
image.png

5.2 映射

image.png

5.2.2 流的扁平化

image.png
image.png
image.png

5.3 查找和匹配

image.png

5.3.1 检查谓语是否至少匹配一个元素

image.png

5.3.2 检查谓语是否匹配所有元素

image.png
image.png

5.3.3 查找元素

image.png
image.png

5.4 归约

image.png

5.4.1 元素求和

image.png

5.4.2 最大值和最小值

image.png
image.png

5.5 付诸实践

image.png

5.5.1 领域:交易员和交易

image.png

5.5.2 解答

image.png

5.6 数值流

image.png

5.6.1 原始类型流特化

image.png
image.png

5.6.3 数值流应用:勾股数

image.png

5.7 构建流

image.png

5.7.1 由值创建流

image.png

5.7.2 由数组创建流

image.png

5.7.3 由文件生成流

image.png
image.png

5.8 小结:

image.png

第六章: 用流收集数据

image.png

6.1 收集器简介:

image.png

6.1.1 收集器用作高级归约

image.png
image.png

6.2 归约和汇总:

image.png

6.2.1 查找流中的最大值和最小值

image.png

6.2.2 汇总:

image.png
image.png

6.2.3 连接字符串:

image.png
image.png
image.png

6.3 分组:

image.png
image.png

6.3.2 按子组收集数据

image.png
image.png
image.png

6.4.1 分区的优势

image.png
image.png

6.5 收集器接口

image.png

6.5.1 理解Collector接口声明的方法:

image.png
image.png
image.png

6.5.2 全部融合到一起

image.png

6.6 开发你自己的收集器以获得更好的性能

image.png

6.6.1 仅用质数做除数

image.png

6.6.2 比较收集器的性能

image.png
image.png

第七章: 并行数据处理与性能

image.png

7.1 并行流

image.png
image.png
image.png

7.1.3 正确使用并行流

image.png

7.1.4 高效使用并行流

image.png

7.2 分支、合并框架

image.png
image.png

7.2.3 工作窃取

image.png
image.png
image.png

小结:

image.png

第八章:重构、测试和调试

image.png

8.1 为改善可读性和灵活重构代码

8.1.1 改善代码的可读性

image.png

8.1.2 从匿名类到Lambda表达式的转换

image.png
image.png

8.1.4 从命令式的数据处理切换到Stream

image.png
image.png
image.png

8.2.1 策略模式

image.png

8.2.2 模板方法

image.png

8.2.3 观察者模式

image.png

8.2.4 责任链模式

image.png

8.2.5 工厂模式

image.png

8.3 测试Lambda表达式

image.png

8.3.1 测试可见Lambda函数的行为

image.png

8.3.2 测试使用Lambda的方法的行为

image.png

8.3.3 将复杂的Lambda表达式分到不同的方法

image.png

8.3.4 高阶函数的测试

image.png

8.4 调试

8.4.1 查看栈跟踪

image.png

8.4.2 使用日志调试

image.png

8.5 小结:

image.png

第九章:默认方法

image.png

9.1 不断演进的API

image.png

9.1.1 初始化版本的PAI

image.png

9.1.2 第二版API

image.png
image.png

9.2 概述默认方法

image.png

9.3 默认方法的使用模式

image.png

9.3.1 可选方法

image.png

9.3.2 行为的多继承

image.png
image.png

9.4 解决冲突的规则

image.png

9.4.1 解决问题的三条规则

image.png

9.4.2 选择提供了最具体的默认方法的接口

image.png

9.4.3 冲突及如何显式地消除歧义

image.png
image.png
image.png

第十章: 用Optional取代null

image.png
image.png

10.1.1 采用防御式检查减少nullpointerException

image.png

10.1.2 null 带来的种种问题

image.png

10.1.3 其他语言中null的替代品

image.png
image.png

10.3 应用Optional的几种模式

image.png

10.3.2 使用map从Optional对象中提取和转换值

image.png

10.3.3 使用flatMap链接optional对象

image.png
image.png

10.3.4 默认行为及解引用Optinal对象

image.png

10.3.5 两个Optional对象的组合

image.png

10.3.6 使用filter剔除特定的值

image.png

10.4 使用Optional的实战实例

image.png

10.4.1 用Optional封装可能为null的值

image.png

10.4.2 异常与Optinal对比

image.png

10.4.3 把所有内容整合起来

image.png

10.5 小结:

image.png

第十一章: 组合式异步编程

image.png
image.png

11.1 Future接口的局限性

image.png

11.1.2 使用CompletableFuture构建异步应用

image.png

11.2 实现异步API

image.png

11.2.1 将同步方法转换异步方法

image.png
image.png

11.3 让你的代码免受阻塞之苦

image.png

11.3.2 使用completableFure发起异步请求

image.png

11.3.3 寻找更好的方案

image.png

11.3.4 使用定制的执行器

image.png
image.png
image.png

11.4.2 使用Discount服务

image.png

11.4.3 构造同步和异步操作

image.png

11.4.4 将两个CompletableFuture对象整合起来,无论他们是否存在依赖

image.png
image.png

11.4.5 对Future和CompletableFuture的回顾

image.png
image.png
image.png

11.5.2 付诸实践

image.png

第十二章:新的日期和时间API

image.png
image.png

12.1.3 机器的日期和时间格式

image.png

12.1.4 定义Duration和Period

image.png
image.png
image.png
image.png

12.2.2 打印输出及解析日期-时间对象

image.png
image.png

12.3.1 利用和UTC、格林时间的固定偏差计算时区

image.png

12.3.2 使用别的日历系统

image.png

12.4 小结:

image.png

第四部分: 超越Java8

image.png

13.1 实现和维护系统

image.png

13.1.1 共享的可变数据

image.png

13.1.2 声明式编程

image.png

13.1.3 为什么要采用函数式编程

image.png

13.2 什么是函数式编程

image.png
image.png

13.2.2 引用透明性

image.png

13.2.3 面向对象的编程和函数式的对比

image.png

13.2.4 函数式编程实战

image.png

13.3 递归和迭代

image.png

13.4 小结:

image.png

第十四章:函数式编程的技巧

image.png

14.1 无处不在的函数

image.png

14.1.1 高阶函数

image.png

14.1.2 科里化

image.png

14.2 持久化数据结构

image.png

14.2.1 破坏式更新和函数式更新的比较

image.png

14.2.2 另一个室友Tree的例子

image.png

14.2.3 采用函数式的方法

image.png

Stream的延迟计算

image.png

14.3.2 创建你自己的延迟列表

image.png

14.4 模式匹配

image.png

14.4.1 访问者设计模式

image.png

14.4.2 用模式匹配力挽狂澜(li wan kuang lan)

image.png

14.5 杂项

14.5.1 缓存或记忆表

image.png

14.6 小结:

image.png

第十五章: 面向对象和函数式编程的混合:Java8和Scala的比较

image.png

15.1 Scala简介

image.png
image.png

3.使用集合

image.png

Stream

image.png

Option

image.png

15.2 函数

image.png

15.2.1 Scala中的一等函数

image.png

15.2.2 匿名函数和闭包

image.png

15.2.3 科里化

image.png

15.3 类和trait

image.png
image.png

15.4 小结:

image.png

第十六章:结论以及Java的未来

image.png

16.1.1 行为参数化(Lambda以及方法引用)

image.png

16.1.2 流

image.png

16.1.3 CompletableFuture

image.png

16.1.4 Optional

image.png

16.1.5 默认方法

image.png

16.2 Java的未来

image.png

16.2.1 集合

image.png

16.2.2 类型系统的改进

image.png

16.2.3 模式匹配

image.png

16.2.4 更加丰富的泛型形式

image.png

16.2.5 对不变性的更深层支持

image.png

16.2.6 值类型

image.png
image.png

16.3 写在最后的话

image.png

其他语言特性的更新

image.png

重复注解

image.png

类库的更新

image.png
image.png
image.png

如何以并发方式在同一个流操作多种操作

image.png
image.png
image.png

Lambda表达式和JVM字节码

image.png
image.png