网站制作方案去哪找在线企业管理培训课程
本节课对Scala进行了系统的学习,先是学习了它的简介,了解到它融合了面向对象与函数式编程特点,是一种多范式的编程语言,运行于Java平台,应用广泛,兼容现有的 Java 程序,Scala是基于Java的,它运行于 Java 虚拟机(JVM)之上,但却高于Java。同时掌握了基础语法,如交互式编程、脚本形式、标识符、关键字、注释、空格、换行符等,变量声明有var与val的不同用法,数据类型涵盖常用的数值、字符等类型;还接触到了控制结构,例如条件判断、循环语句等。
Scala中,对于标识符也是有一定的规则:1.字母数字组合:标识符可以由字母、数字和下划线组成。不过,标识符不能以数字开头。2.大小写敏感:Scala 是大小写敏感的语言,这意味着 myVar
和 MyVar
是不同的标识符。3.特殊字符:Scala 允许在标识符中使用一些特殊字符,如 +
、-
、*
、/
、:
等。对命名规范也有一定的规则:1.变量和方法:通常采用驼峰命名法,首字母小写,后续每个单词首字母大写。2.类和特质:一般使用大驼峰命名法,即每个单词的首字母都大写。3.常量:通常使用全大写字母,单词之间用下划线分隔。
Scala
Scala(Scalable Language)是一种多范式的编程语言,其设计的初衷是要集成面向对象编程和函数式编程的各种特性。Scala运行于JVM平台(Java虚拟机),并兼容现有的Java程序;Scala 的编译模型(独立编译,动态类加载)与 Java 和 C# 一样,所以 Scala 代码可以调用 Java 类库(对于.NET实现则可调用.NET类库)。
Scala语言的特点
优雅:这是框架设计师第一个要考虑的问题,框架的用户是应用开发程序员,API是否优雅直接影响用户体验。
速度快:Scala语言表达能力强,一行代码抵得上Java多行,开发速度快;Scala是静态编译的,所以速度会快很多。
能融合到Hadoop生态圈:Hadoop现在是大数据事实标准,Spark并不是要取代Hadoop,而是要完善Hadoop生态。JVM语言大部分可能会想到Java,但Java做出来的API太丑,或者想实现一个优雅的API太费劲。
Scala 特性
面向对象特性
Scala 是一种高度表达性的编程语言,它结合了面向对象编程和函数式编程的最佳特性。
类和对象: Scala 支持类和对象,可以定义属性和方法。
继承和多态: 支持类的继承和多态,可以创建层次结构和重用代码。
抽象类和特质: 可以定义抽象类和特质(traits),用于定义接口和实现部分行为。
封装: 支持访问控制修饰符(public、protected、private),实现数据的封装。
函数式编程
高阶函数: 函数可以作为参数传递给另一个函数,或者从另一个函数返回。
不可变性: 默认使用不可变数据结构,有助于避免副作用,提高代码的并发安全性。
模式匹配: 提供强大的模式匹配功能,可以解构复杂数据结构,进行条件判断。
闭包: 支持闭包,可以捕获并记住其创建时的变量。
类型系统
静态类型:Scala具备类型系统,通过编译时检查,保证代码的安全性和一致性。
类型推断: 强大的类型推断机制,可以减少代码中的类型声明,提高代码的可读性。
泛型编程: 支持泛型,允许编写更加通用和可复用的代码。
类型系统扩展: 包括协变(covariance)和逆变(contravariance)、特质(traits)混入等。
扩展性
Scala的设计秉承一项事实,即在实践中,某个领域特定的应用程序开发往往需要特定于该领域的语言扩展。
并发性
Akka 框架: 基于 Actor 模型,用于构建并发、分布式和容错的应用程序。
Futures 和 Promises: 提供异步编程的抽象,简化并发任务的管理。
Scala 并发集合: 提供线程安全的数据结构,方便并发编程。
强大的标准库
集合框架: 提供丰富的不可变和可变集合类,如List、Set、Map等。
字符串处理: 提供强大的字符串操作和正则表达式支持。
IO操作: 支持文件和网络IO操作。
与 Java 互操作性
无缝调用: Scala 可以直接调用 Java 代码,并且可以在 Java 中调用 Scala 代码。
Java标准库: 可以使用 Java 的标准库和框架,利用其丰富的生态系统。
Scala与Java的关系
Scala与Java的关系是非常紧密的,因为Scala是基于JVM(JAVA虚拟机)的一门编程语言。所有Scala的代码,都需要经过编译为字节码,然后交由JVM来运行。
所以Scala和Java是可以无缝互操作的。Scala可以任意调用Java的代码。所以Scala与Java的关系是非常非常紧密的。
Scala是基于Java的,但却高于Java。
Scala 基础语法
Scala 与 Java 的最大区别是:Scala 语句末尾的分号 ; 是可选的。
我们可以认为 Scala 程序是对象的集合,通过调用彼此的方法来实现消息传递。接下来我们来理解下,类,对象,方法,实例变量的概念:
对象 -对象有属性和行为。例如:一只狗的状属性有:颜色,名字,行为有:叫、跑、吃等。对象是一个类的实例。
类 -类是对象的抽象,而对象是类的具体实例。
方法 -方法描述的基本的行为,一个类可以包含多个方法。
字段 -每个对象都有它唯一的实例变量集合,即字段。对象的属性通过给字段赋值来创建。
基本语法
Scala 基本语法需要注意以下几点:
区分大小写-Scala是大小写敏感的,这意味着标识Hello 和 hello在Scala中会有不同的含义。
类名-对于所有的类名的第一个字母要大写。
如果需要使用几个单词来构成一个类的名称,每个单词的第一个字母要大写。
示例:class MyFirstScalaClass
方法名称-所有的方法名称的第一个字母用小写。
如果若干单词被用于构成方法的名称,则每个单词的第一个字母应大写。
示例:def myMethodName()
程序文件名-程序文件的名称应该与对象名称完全匹配(新版本不需要了,但建议保留这种习惯)。
保存文件时,应该保存它使用的对象名称(记住Scala是区分大小写),并追加".scala"为文件扩展名。 (如果文件名和对象名称不匹配,程序将无法编译)。
示例: 假设"HelloWorld"是对象的名称。那么该文件应保存为'HelloWorld.scala"
def main(args: Array[String]-Scala程序从main()方法开始处理,这是每一个Scala程序的强制程序入口部分。
Scala 关键字
Scala 注释
Scala 类似 Java 支持单行和多行注释。多行注释可以嵌套,但必须正确嵌套,一个注释开始符号对应一个结束符号。注释在 Scala 编译中会被忽略,实例如下:
空行和空格
一行中只有空格或者带有注释,Scala 会认为其是空行,会忽略它。标记可以被空格或者注释来分割。
换行符
Scala是面向行的语言,语句可以用分号(;)结束或换行符。Scala 程序里,语句末尾的分号通常是可选的。如果你愿意可以输入一个,但若一行里仅 有一个语句也可不写。另一方面,如果一行里写多个语句那么分号是需要的。例如
Scala 包
定义包
Scala 使用 package 关键字定义包,在Scala将代码定义到某个包中有两种方式:
第一种方法和 Java 一样,在文件的头定义包名,这种方法就后续所有代码都放在该包中。 比如:
第二种方法有些类似 C#,如:
第二种方法,可以在一个文件中定义多个包。
引用
Scala 使用 import 关键字引用包。
import语句可以出现在任何地方,而不是只能在文件顶部。import的效果从开始延伸到语句块的结束。这可以大幅减少名称冲突的可能性。