1、什么是Scala与历史
1.1概述
Scala是Spark编程常用的语言之一。Scala是Scalable Language的简写,是一门多范式的编程语言。Scala是运行在JVM上的多范式编程语言,同时支持面向对象和面向函数编程。
1.2历史
Scala编程语言是由联邦理工学院洛桑(EPFL)的Martion Odersky(马丁.奥德斯基)于2001年基于Funnel的工作开始设计并开发的,设计初衷是要集成面向对象编程和函数式编程的各种特性。由于Martiion Odersky之前的工作是开发通用Java和Java c,所以基于Java平台的Scala语言于2003年底/2004年初发布。
2、Scala的特性
(1)面向对象
scala是一种纯粹的面向对象语言。一个对象的类型和行为是由类和特征来描述的。类通过子类化和基于灵活的混合类来进行扩展,作为多重继承的一个可靠性解决方案。
(2)函数式编程
Scala提供了一个轻量级语法来定义匿名函数,它也支持高阶函数,允许函数嵌套,并支持柯里化。Scala的case class 与其内置的Pattern Matching模型支持函数式编程语言中的代数类型。Singleton对象提供了一种方便的方法来组合不属于类的函数。用户还可以使用Scala的模式匹配,编写类似正则表达式的代码来处理XML数据。
(3)静态类型
Scala配备了一种表现型的系统,它以静态的方式进行抽象,以安全和连贯的方式进行使用。系统支持通用类、内部类、抽象类和复合类作为对象成员,也支持隐式参数、转换和多态方