Java 8实战之读书笔记五:超越Java 8

四、超越Java 8

第13章 函数式的思考

下面是这一章中你应该掌握的关键概念。
     从长远看,减少共享的可变数据结构能帮助你降低维护和调试程序的代价。
     函数式编程支持无副作用的方法和声明式编程。
     函数式方法可以由它的输入参数及输出结果进行判断。
     如果一个函数使用相同的参数值调用,总是返回相同的结果,那么它是引用透明的。采用递归可以取得迭代式的结构,比如while循环。
     相对于Java语言中传统的递归,“尾递”可能是一种更好的方式,它开启了一扇门,让我们有机会最终使用编译器进行优化。

第14章 函数式编程的技巧

下面是本章中你应该掌握的重要概念。
     一等函数是可以作为参数传递,可以作为结果返回,同时还能存储在数据结构中的函数。
     高阶函数接受至少一个或者多个函数作为输入参数,或者返回另一个函数的函数。 Java中典型的高阶函数包括comparing、 andThen和compose。
     科里化是一种帮助你模块化函数和重用代码的技术。

     持久化数据结构在其被修改之前会对自身前一个版本的内容进行备份。因此,使用该技术能避免不必要的防御式复制。
     Java语言中的Stream不是自定义的。
     延迟列表是Java语言中让Stream更具表现力的一个特性。延迟列表让你可以通过辅助方法(supplier)即时地创建列表中的元素,辅助方法能帮忙创建更多的数据结构。
     模式匹配是一种函数式的特性,它能帮助你解包数据类型。它可以看成Java语言中switch语句的一种泛化。
     遵守“引用透明性”原则的函数,其计算结构可以进行缓存。
     结合器是一种函数式的思想,它指的是将两个或多个函数或者数据结构进行合并。

第15章 面向对象和函数式编程的混合:  Java 8和Scala的比较

下面是这一章中介绍的关键概念和你应该掌握的要点。
     Java 8和Scala都是整合了面向对象编程和函数式编程特性的编程语言,它们都运行于JVM之上,在很多时候可以相互操作。
     Scala支持对集合的抽象,支持处理的对象包括List、 Set、 Map、 Stream、 Option,这些和Java 8非常类似。不过,除此之外Scala还支持元组。
     Scala为函数提供了更加丰富的特性,这方面比Java 8做得好, Scala支持:函数类型、可以不受限制地访问本地变量的闭包,以及内置的科里化表单。
     Scala中的类可以提供隐式的构造器、 getter方法以及setter方法。
     Scala还支持trait,它是一种同时包含了字段和默认方法的接口。

第16章 结论以及Java的未来

本书探索了Java 8新增加的一系列新特性;它们所代表的可能是自Java创建以来最大的一次演进——唯一可以与之相提并论的大的演进也是在10年之前,即Java 5中所引入的泛型。这一章里我们还了解了Java进一步发展所面临的压力。用一句话来总结,我们会说:
    Java 8已经占据了一个非常好的位置,可以暂时歇口气,但这绝不是终点!

本章主要还是对之前内容的总结,主要的还是偏概念。

另外还有些其他语言特性的更新及类库的更新,最好还是推荐看一下这本书。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值