学习Scala语言,不仅仅意味着熟悉新的API,更重要的是一种思维方式的转变。从原有的面向对象编程(OO)到函数式编程(FP)的思想。...本书面向实际的使用场景,提供了大量的Scala实例,同时,也给出底层的原理和相关的参考。对于Scala新手来说这是一本非常不错的入门书,对于老手来说也是一本夯实基础,检视自己所学知识的好书。
什么是函数式编程 函数式编程是指只用纯函数来构造程序, 函数是没有副作用的 先说一下什么是副作用: 普通一个函数是输入一个参数输出一个返回值,而带有副作用的函数不仅仅返回一个值,还带有其它的操作: 比如...对于一个输入类型A和输出类型B的函数f(scala里面写为:A=>B 读作 A 到 B) 它是一种将所有A类型的值a关联到某个确切的B类型的值b的运算过程,即b完全由a来决定,任何内部或者外部过程的状态改变都不会影响到...变量的不可变性: "变量"这个词在函数式编程中和在传统的面向对象编程是不同的,面向对象编程认为变量是可变的,然而,在函数式编程中,变量时不可变的....Scala中的函数式编程 作为一门面向对象与函数式的混合范式语言,Scala并不强制函数必须是纯函数,也并不要求变量时不可变的(但是尽量将变量设为不可变) 在前面几个章节中,我们学习了Scala的高阶函数...由于函数在 Scala 中是第一等的,因此我们定义了表示函数的变量。不过,这不是简单的替换,在这里 multiplier 引用了 factor,而不是将其硬编码为 2。
如Scala官网宣称的:“Object-OrientedMeetsFunctional”,这一句当属对Scala最抽象的精准描述,它把近二十年间大行其道的面向对象编程与旧而有之的函数式编程有机结合起来,...在我掌握的众多编程语言之中,Scala无疑是其中最让我感到舒适的,如Scala官网宣称的:“Object-OrientedMeetsFunctional”,这一句当属对Scala最抽象的精准描述,它把近二十年间大行其道的面向对象编程与旧而有之的函数式编程有机结合起来...伴生对象与伴生类 伴生对象与伴生类在Scala的面向对象编程方法中占据极其重要的位置,例如Scala中许多工具方法都是由伴 生对象提供的。...在编写Scala代码的过程中,将处处体现出它的函数式编程风格,高效而简洁。...模式匹配(PatternMatching) Scala的模式匹配实现非常强大。模式匹配为编程过程带来了莫大便利,在Scala并发编程中也得到了广泛应用。 ?
一.Scala简介 Scala是一种多范式的编程语言,其设计的初衷是要集成面向对象编程和函数式编程的各种特性。Scala运行于Java平台(Java虚拟机),并兼容现有的Java程序。...三.安装 因为Scala是运行在JVM平台上的,所以安装Scala之前要安装JDK 1.Windows安装Scala编译器 下载scala-2.11.msi后点击下一步就可以了 配置环境变量 SCALA-HOME...;%SCALA-HOME%\lib\dt.jar;%SCALA-HOME%\lib\tools.jar;%SCALA-HOME%\bin; 2.Linux安装Scala编译器 下载Scala tar -...;%SCALA-HOME%\lib\dt.jar;%SCALA-HOME%\lib\tools.jar;%SCALA-HOME%\bin; 2.Linux安装Scala编译器 下载Scala tar...= x*y def 定义方法关键字 x和y是参数列表 :Int 方法返回值类型 x*y 方法体 7.2定义函数 val f1=(x:Int,y:Int) => x+y 7.3方法和函数区别 在函数式编程语言中
scala - 面向对象编程 定义类来说不需要修饰,直接使用 class 创建即可。...创建对象 val helloWorld = new HelloWorld helloWorld.getName getter 与 setter 定义不带 private 的 var field,此时 scala...Java 风格的 getter 和 setter 方法 Scala 的 getter 和 setter 方法的命名和 Java 是不同的,是 field 和 field_= 的方式。...如果要让 Scala 自动生成 Java 风格的 getter 和 setter 方法,在 field 添加 @BeanProperty 注解即可。...辅助 constructor 在 Scala 中,可以结合类定义多个辅助 constructor ,类似 Java 中的构造函数重载。
Scala和Kotlin脚本编程 Scala和Kotlin作为运行在JVM上的编程语言,解决了Java的很多痛点。...Kotlin脚本编程 Kotlin脚本的扩展名为kts,运行命令为kotlinc -script HelloWorld示例 下面我们来看一个HelloWorld示例: 新建名称为...Scala脚本编程 Scala脚本的扩展名仍为scala,运行命令为scala ,和普通的Scala类一样。...Scala和Kotlin脚本编程的异同 Scala脚本的扩展名和执行方式和普通Scala类一样;Kotlin脚本的扩展名为kts,执行的时候需要加-script参数 Scala提供了对于外部命令调用的快捷方法...,可以运行Ammonite Scala脚本 注:Ammonite项目扩展了Scala的脚本功能,添加了很多额外的特性,甚至提供了一个基于Scala的Shell(类似于Bash Shell)。
函数式编程 将函数赋值给变量 Scala 中的函数是一等公民,可以独立定义,独立存在,而且可以直接将函数作为值赋值给变量。...这个功能是极其强大的,也是 Java 这种面向对象的编程语言所不具备的。 接收其他函数作为参数的函数,也被称作高阶函数(higher-order function)。...Scala通过为每个函数创建对象来实现闭包,实际上对于 getGreetingFunc 函数创建的函数, msg 是作为函数对象的变量存在的,因此每个函数才可以拥有不同的 msg,Scala 编译器会确保上述闭包机制...由于 Scala 是可以调用 Java 的代码的,因此当我们调用 Java 的某个方法时,可能就不得不创建 SAM 传递给方法,非常麻烦;但是 Scala 又是支持直接传递函数的。...此时就可以使用 Scala 提供的,在调用 Java 方法时,使用的功能,SAM 转换,即将 SAM 转换为 Scala 函数。 要使用SAM转换,需要使用 Scala 提供的特性,隐式转换。
面向对象编程 解决问题,分解对象,行为,属性,然后通过对象的关系以及行为的调用来解决问题。...对象:用户; 行为:登录、连接jdbc、读取数据库 属性:用户名、密码 Scala语言是一个完全面向对象编程语言。...万物皆对象 函数式编程 解决问题时,将问题分解成一个一个的步骤,将每个步骤进行封装(函数),通过调用这些封装好的步骤,解决问题 例如:请求->用户名、密码->连接jdbc->读取数据库 Scala...语言是一个完全函数式编程语言。...万物皆函数 在Scala中函数式编程和面向对象编程融合在一起了。
既然谈到实用编程,就应该不单止了解试试一个新的编程语言那么简单了,最好通过实际的开发项目实例来演示如何编程。...心目中已经有了一些设想;想用Scala泛函编程搞一个开源的数据平台应用系统,也就是在云平台PaaS层对上一层后台的数据应用平台。...因为整个开发过程是以Scala泛函编程为主体并且会涉及到许多新的软件、中间件、子功能、开发技术,所以在这里先过一下:数据应用平台是一个寄存在云端的通用数据应用后台系统,与云端虚拟环境紧密结合,以一套定制的...大数据数据库:Hbase(取其通用)、Accumulo(取其安全) 4、大数据环境:Hadoop、Spark 5、应用平台:Akka,可以跨JVM的分布式应用平台 6、Search:Lucent,可以用Scala
一、下载scala安装包 Linux:scala-2.12.11.tgz window:scala-2.12.11.zip 二、上传安装包到Linux 安装路径一般在 /usr/local 下...cd /usr/local rz 三、解压scala安装包 tar -zxvf /usr/local/scala-2.12.11.tgz -C /usr/local/ 四、创建软链接 ln -s /usr.../local/scala-2.12.11 /usr/local/scala 五、配置环境变量 编辑 /etc/profile 文件,添加变量 export SCALA_HOME=/usr/local/scala..._181-cloudera export SCALA_HOME=/usr/local/scala export CLASSPATH=....}/bin source /etc/profile 文件 source /etc/profile 查看版本验证 scala -version Scala code runner version 2.12.11
面向对象编程 - 继承 复用 ~ 可扩展性 ~ 可维护性 extends 使用 extends 关键字表示继承。 继承就代表,子类可以从父类继承父类的 field 和 method 。...override 和 super 在 Scala 中,如果子类要覆盖一个父类中非抽象方法,则必须使用 override 关键字。 override 关键字可以帮助我们尽早地发现代码里的错误。...case _=> println("unknown type") } protected scala 中同样可以使用 protected 关键字来修饰 field 和 method ,这样在子类中就不需要...Student println("Hi, my name is" + name + ", your name is " + s.name) 调用父类的 constructor 在 Scala...抽象 field 意味着,scala 会根据自己的规则,为 var 或 val 类型的 field 生成对应的 getter 和 setter 方法,但是父类中是没有该 field 的。
参考 菜鸟教程 深入理解 Scala 中的闭包(Closures) ---- 递归 所谓递归,就是一个函数内,被自身函数所调用,形成循环调用的现象称为递归调用; 案例:经典的斐波拉契 def...在scala中 编写递归,必须指定返回值类型 def fibonacci(n:Int):Int={} // :Int 必须指定 ---- 控制抽象 控制抽象不能单独定义,只能作为方法的参数类型存在,控制抽象代表的就是一个块表达式...在scala中可以通过关键字 lazy 实现懒加载。 image.png a 是一个普通的值,代码从小往下执行,完成了a的初始化,结果值为10。
一、Scala是什么 Scala是一种多范式的编程语言,其设计的初衷是要集成面向对象编程和函数式编程的各种特性。Scala运行于Java平台(Java虚拟机),并兼容现有的Java程序。 ...SCala 的函数式编程简化了用简单部件搭建实际应用的过程。它的面向对象特性又使它便于构造大型系统并使它们适应新的需求。Scala中这两种风格的组合使得表达新的编程模式和新的组件抽象成为可能。...同样也让这种易读、简洁的编程风格成为顺理成章的事。而且由于 SCala 良好的延展性,因此用它来编程也充满乐趣。...四、Scala的特征 一致性: 尽管Scala融合了静态类型系统、面向对象、函数式编程等语言特性,但却很少能看出融合的痕迹。Scala是我见到融合最多语言特性而又不显得杂乱的编程语言之一。...本文部分内容参考 什么吗是Scala?为什么要学Scala? Scala 是一门怎样的语言,具有哪些优缺点? 编程语言scala有哪些特点
Scala函数式编程 函数式编程基础 函数定义/声明 函数运行机制 递归//难点 [最短路径,邮差问题,迷宫问题, 回溯] 过程 惰性函数和异常 函数式编程高级 值函数(函数字面量) 高阶函数 闭包 应用函数...柯里化函数,抽象控制… 在scala中,函数式编程和面向对象编程融合在一起,学习函数式编程式需要oop的知识,同样学习oop需要函数式编程的基础。...在学习Scala中将方法、函数、函数式编程和面向对象编程明确一下: 在scala中,方法和函数几乎可以等同(比如他们的定义、使用、运行机制都一样的),只是函数的使用方式更加的灵活多样。...比如:在Scala当中,函数是一等公民,像变量一样,既可以作为函数的参数使用,也可以将函数赋值给一个变量....面向对象编程是以对象为基础的编程方式。 在scala中函数式编程和面向对象编程融合在一起了 。 在学习Scala中将方法、函数、函数式编程和面向对象编程关系分析图: ?
Akka用Scala 语言编写,同时提供了 Scala 、JAVA 的开发接口。...对并发模型进行了更高的抽象 异步、非阻塞、高性能的事件驱动编程模型 轻量级事件处理(1GB内存可容纳百万级别个Actor) 为什么 Actor 模型是一种处理并发问题的解决方案呢?...Actor模型的出现解决了这个问题,简化并发编程,提升程序性能。 ? ...> 2.11 2.4.17scala-library ${scala.version}
Scala的函数(function)还是值得提的。函数可以当作标准的对象使用:可以当作另一个函数的输入参数或者结果值。...在Scala编程里匿名函数(anonymous function or lamda function)或函数文本(function literal)的使用也很普遍。...以上匿名函数的各种表述形式可以参考一下Scala语言教程。
本篇作为scala快速入门系列的第十六篇博客,为大家带来的是关于函数式编程的相关内容。 ?...函数式编程 我们将来使用Spark/Flink的大量业务代码都会使用到函数式编程。下面的这些操作是学习的重点。...我们接下来将学习scala的函数式编程,使用 foreach 方法来进行遍历、迭代。它可以让代码更加简洁。 方法签名 ?...如果方法参数是函数,如果出现了下划线,scala编译器会自动将代码封装到一个函数中 参数列表也是由scala编译器自动处理 ---- 映射|map 集合的映射操作是将来在编写Spark/Flink...对scala感兴趣的朋友可以持续关注哟~
本篇作为scala快速入门系列的第三十八篇博客,为大家带来的是关于Actor并发编程的内容。 ?...---- Actor并发编程 1.Actor介绍 scala的Actor并发编程模型可以用来开发比Java线程效率更高的并发程序。...我们学习scala Actor的目的主要是为后续学习Akka做准备。...Actor并发编程模型 Actor并发编程模型,是scala提供给程序员的一种与Java并发编程完全不一样的并发编程模型,是一种基于事件模型的并发机制。...[NOTE] scala在2.11.x版本中加入了Akka并发编程框架,老版本已经废弃。Actor的编程模型和Akka很像,我们这里学习Actor的目的是为学习Akka做准备。
应用层 80/20原则:80%的代码是 纯函数,其余如处理IO,数据库,用户交互等方面的20%的代码也应该尽量轻量级 培养面向表达式的编程思维,培养函数式编程思维 用Actor模型实现并发功能...将更多的 行为 从 类里 移到 更细粒度的 trait中 代码层 坚持写纯函数 习惯将函数作为变量和参数进行传递 重点学习scala的集合类和其API 尽量使用immutable代码,优先使用...Expression Oriented Programming 面向表达式的编程指每一语句都是一个表达式,有返回值,无副作用, 函数式编程语言都应该这样!...相对的statement编程是不返回数据,使用副作用!...scala中的if/else match/case try/catch 都有返回值 优点:更易理解的代码;没副作用,更容易测试 与scala语法绑定;更适合多核计算机 使用match/case
本文链接:https://blog.csdn.net/u014365862/article/details/103085642 原文地址:https://liam-blog.ml/2019/09/22/Scala-Concurrency-Executor...ExecutionContext Scala另外提供了ExecutionContext和Future来简化线程池的使用,Future可以接受一个ExecutionContext类型的隐式参数,将传入的函数提交到...package io.github.liam8.con import java.util.concurrent.Executors import scala.concurrent....{Await, ExecutionContext, ExecutionContextExecutorService, Future} import scala.concurrent.duration._...Futures Made Easy with Scala 本文代码 Github仓库
领取专属 10元无门槛券
手把手带您无忧上云