Scala是一种多范式的编程语言,其设计的初衷是要集成面向对象编程和函数式编程的各种特性。Scala运行于Java平台(Java虚拟机),并兼容现有的Java程序。
Scala语言的名称来自于"可伸展的语言"。之所以这样命名,是因为它被设计成可以随着使用者的需求而扩展。Scala的应用范围很广,从编写简单脚本,到建立大型系统。 它在许多方面体现了面向对象和函数式编程的熔合;或许这种熔合比其他那些广泛使用的语言体现得还要深入。在可伸展性方面,这两种编程风格具有互补的力量。SCala 的函数式编程简化了用简单部件搭建实际应用的过程。它的面向对象特性又使它便于构造大型系统并使它们适应新的需求。Scala中这两种风格的组合使得表达新的编程模式和新的组件抽象成为可能。同样也让这种易读、简洁的编程风格成为顺理成章的事。而且由于 SCala 良好的延展性,因此用它来编程也充满乐趣。
从技术层面上讲,Scala是一种把面向对象和函数式编程理念加入静态类型语言的混合体,它可以
1.优雅:这是框架设计师第一个要考虑的问题,框架的用户是应用开发程序员,API是否优雅直接影响用户体验。
2.速度快:Scala语言表达能力强,一行代码抵得上Java多行,开发速度快;Scala是静态编译的,所以和JRuby,Groovy比起来速度会快很多。
3.能融合到Hadoop生态圈:Hadoop现在是大数据事实标准,Spark并不是要取代Hadoop,而是要完善Hadoop生态。JVM语言大部分可能会想到Java,但Java做出来的API太丑,或者想实现一个优雅的API太费劲。
Scala的追求不在于Ruby的“好玩”,Python的“简单“,Scala的追求在于速度与性能的提升,怎样有效率就怎样弄。Scala不把程序员当傻子,Scala "Don Giovanni"项目创始人马丁·奥德斯基在视频中说的很清楚:“Scala现在是为聪明人创造的,以后也是为聪明人服务的。”所以不同于Python让程序员用一种方法做所有事情,Scala提供一整套工具,让程序员自由选择,无论是mutable数据结构,immutable数据结构,并行(parallel)数据结构。然后在这些选择中,Scala再针对他们进行算法层面的特殊优化。Scala相信程序员的聪明才智,让程序员自行选择合适的结构,以针对变化万千的任务需求,这点是Scala做得极好的地方。