第1章 函数式编程思想
1-1 课程介绍
Scala 是高逼格实用的编程语言
1-2 Scala函数式编程思想
纯函数没有副作用
引用透明:对于相同的输入,总是得到相同的输出
如果F(x)的参数x和函数体都是应用透明的,那么函数f是纯函数
函数是一等公民:一切都是计算,函数式编程中只有表达式,变量,函数都是表达式
高阶函数
闭包
表达式求值策略:严格求值(Call By Value)和非严格求值(Call By Name)
惰性求值(Lazy Evaluation):当定义这个表达式的时候,不会立即去求值,
只有当第一次用到这个表达式的时候,才会去求值。
递归函数(Recursive Function)递归实现循环
尾递归(Tail Recursion)
函数式编程的优点
生产效率高:同样功能的程序,Lisp代码的长度可能是C代码的1/7~1/10
易于推理(Reasoning)
并行编程
多核计算、云计算
函数式编程的崛起
摩尔定律:随着技术的进步,相同的价格将会买到性能更高的产品。
多核处理器
云计算时代
第2章 Scala开发环境
2-1 Scala环境搭建
# step1 安装JDK 8 (jdk-8u191-macosx-x64.dmg)
https://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html
# step2 安装 scala-2.12.7.tgz
https://www.scala-lang.org/download/
# mac 安装命令:
brew update
brew install scala
# step3 SBT (simple build tool) 构建工具
https://www.scala-sbt.org/download.html
# mac 安装命令:
brew install sbt@1
# step4 REPL (Read Evaluate Print Loop)
交互式的程序运行环境,轻量级的,用于做实验的。
# 两种启动方法:
scala 起repl界面
sbt console 起repl界面
# step5 IDE
1.The Scala IDE (based on Eclipse) (http://scala-ide.org/download/sdk.html)
2.Intellij IDEA with Scala plugin
3.Netbeans IDE with the Scala plugin
java -version,scala -version,sbt 搭建成功
scala 起 repl
sbt console 起 repl
首次尝试 scala project
scala exec