怎样学习Scala泛函编程

简介:

     确切来说应该是我打算怎么去学习Scala泛函编程。在网上找不到系统化完整的Scala泛函编程学习资料,只好把能找到的一些书籍、博客、演讲稿、论坛问答、技术说明等组织一下,希望能达到学习目的。关于Scala语言的教材在国内网上还是比较容易找到的;可以到Scala语言官方网站国内Scala社区网站这些地方去看看了解一下;深一点的参考一下在路上,里面包括了一些泛函编程的概念性内容。

   

学习编程语言除了语法语意之外还必须透彻了解编程语言的数据结构(data structure);数据结构在实际项目中的角色,如何应用、如何添加定制;试想想任何一个实际的应用程序没有Array、List、Buffer、String这些数据结构会怎样。泛函编程有一套自己的数据结构。与OOP数据结构不同的是FP数据结构是以数学理论为基础的,必须遵循特定的数学定律。由于Scala是OOP和FP的混合,学习Scala也可以掌握我们所熟悉的那些java data structure。但如果直接使用这些java data structure去做Scala项目开发,那不就等于又回到原路了吗,还费劲去学习Scala干嘛,花点时间把java搞的更精点不是更好吗。曾提到OOP可能无法有效地进行现代云应用系统开发,那么重点还是要学习掌握Scala的泛函编程部分。泛函编程有一套独特的数据结构管理和应用方法。Scalaz是一套完整的泛函数据结构库,是一套开源项目,在许多大型软件中都有使用。那么我的第一个目标就是在以后的编程能充分使用Scalaz,合理调用里面的数据结构(data structure)。不过Scalaz连学习资料甚至说明文档都没有,看来还必须从基本的泛函编程概念开始学习。

    Scala泛函编程学习过程大体分三个部分:

    1)学习泛函编程模式    

    2)了解掌握Scalaz   

    3)用Scala泛函编程实践开发数据平台项目中的各项子系统。

    

    在网上刨过了一大堆书籍和资料后,发现Paul Chiusano和Runar Bjarnason所著“Functional Programming In Scala”写的不错。内容组织的也比较合理;从FP概念到FP数据结构到泛函编程,并且是用Scala做的示范说明。

下面的Scala泛函编程学习部分就以这本书的结构为基础,再把其它零星分散的资料重新组织一下作为进一步的示范说明。 

相关文章
|
22天前
|
分布式计算 大数据 Java
大数据-87 Spark 集群 案例学习 Spark Scala 案例 手写计算圆周率、计算共同好友
大数据-87 Spark 集群 案例学习 Spark Scala 案例 手写计算圆周率、计算共同好友
34 5
|
22天前
|
分布式计算 关系型数据库 MySQL
大数据-88 Spark 集群 案例学习 Spark Scala 案例 SuperWordCount 计算结果数据写入MySQL
大数据-88 Spark 集群 案例学习 Spark Scala 案例 SuperWordCount 计算结果数据写入MySQL
44 3
|
22天前
|
缓存 分布式计算 大数据
大数据-90 Spark 集群 RDD 编程-高阶 RDD容错机制、RDD的分区、自定义分区器(Scala编写)、RDD创建方式(一)
大数据-90 Spark 集群 RDD 编程-高阶 RDD容错机制、RDD的分区、自定义分区器(Scala编写)、RDD创建方式(一)
30 0
|
22天前
|
分布式计算 算法 大数据
大数据-90 Spark 集群 RDD 编程-高阶 RDD容错机制、RDD的分区、自定义分区器(Scala编写)、RDD创建方式(二)
大数据-90 Spark 集群 RDD 编程-高阶 RDD容错机制、RDD的分区、自定义分区器(Scala编写)、RDD创建方式(二)
35 0
|
4月前
|
Scala 开发者
Scala中的模式匹配与高阶函数:探索强大的编程范式
【7月更文挑战第11天】Scala中的模式匹配和高阶函数是两种极其强大的特性,它们不仅提升了代码的表达力和可读性,还使得开发者能够编写出更加灵活和可重用的解决方案。通过
|
6月前
|
安全 编译器 Scala
何时需要指定泛型:Scala编程指南
本文是Scala编程指南,介绍了何时需要指定泛型类型参数。泛型提供代码重用和类型安全性,但在编译器无法推断类型、需要提高代码清晰度、调用泛型方法或创建泛型集合时,应明确指定类型参数。通过示例展示了泛型在避免类型错误和增强编译时检查方面的作用,强调了理解泛型使用时机对编写高效Scala代码的重要性。
42 1
何时需要指定泛型:Scala编程指南
|
6月前
|
Scala 容器
Scala学习--day04--集合、常用方法、案例实操 - WordCount TopN、不同省份的商品点击排行
Scala学习--day04--集合、常用方法、案例实操 - WordCount TopN、不同省份的商品点击排行
105 2
|
6月前
|
消息中间件 分布式计算 大数据
Scala学习--day03--函数式编程
Scala学习--day03--函数式编程
|
6月前
|
Java Scala
Scala学习--day02---控制流、“九层妖塔—杨辉三角”
Scala学习--day02---控制流、“九层妖塔—杨辉三角”
179 1
|
6月前
|
Java 编译器 API
Scala学习--day01变量与数据类型、运算符
Scala学习--day01变量与数据类型、运算符