Scala教程

閱讀(12975) 更新時間(2022-04-19)

Scala 教程 Scala 是一門多範式(multi-paradigm)的程式語言,設計初衷是要整合物件導向程式設計和函數式程式設計的各種特性。


Scala是一門多範式的程式語言,一種類似java的程式語言,設計初衷是實現可伸縮的語言、並整合物件導向程式設計和函數式程式設計的各種特性。

第一個Scala程式

以下是用Scala寫的典型Hello World程式:

實例

##
 object HelloWorld extends App {
   println("Hello, world!")
 }

運行實例»點擊"運行實例"按鈕查看線上實例

#或

實例

object HelloWorld {
   def main(args: Array[String]) {
     println("Hello, world!")
   }
 }

運行實例»點擊"運行實例" 按鈕查看線上實例

#

请注意它与Java的Hello World应用程序有哪些相似之处。一处显著区别在于,Scala版的Hello World程序不通过static关键字把main方法标记为静态方法,而是用object关键字创建了单件。

假设该程序保存为HelloWorld.scala文件,接下来可以通过以下命令行进行编译:

> scalac HelloWorld.scala

若要运行:

> scala -classpath . HelloWorld

这与编译和运行Java的“Hello World”程序是不是很像呢?事实上,Scala的编译和执行模型与Java是等效的,因而它也兼容于Java的构建工具,比如Ant.

直接使用Scala解释器也可以运行该程序,使用选项-i(从文件加载代码)和选项-e(若要运行额外的代码,就得实际执行HelloWorld对象的方法)即可:

> scala -i HelloWorld.scala -e 'HelloWorld.main(null)'

提示:我们的Scala教程将帮助您学习从初级到高级的Scala知识。如果你有任何疑问,请前往PHP中文网Scala社区提出你的问题,会有热心网友为你解答。

Scala特性

支持的编程范式

  • 面向对象特性

Scala是一种纯面向对象的语言,每个值都是对象。对象的数据类型以及行为由类和特质描述。类抽象机制的扩展有两种途径。一种途径是子类继承,另一种途径是灵活的混入机制。这两种途径能避免多重继承的种种问题。

  • 函数式编程

Scala也是一种函数式语言,其函数也能当成值来使用。Scala提供了轻量级的语法用以定义匿名函数,支持高阶函数,允许嵌套多层函数,并支持柯里化。Scala的case class及其内置的模式匹配相当于函数式编程语言中常用的代数类型。

更进一步,程序员可以利用Scala的模式匹配,编写类似正则表达式的代码处理XML数据。在这些情形中,列表推导式功能对编写公式化查询非常有用。

由于JVM不支持尾部递归,Scala也不能完全支持尾部递归优化。不过,Scala编译器可以把某些简单的尾递归优化成循环。

以下代码以函数式风格实现了快速排序算法,可以与Erlang快速排序的例子做个比较:

def qsort(list: List[Int]): List[Int] = list match {
  case Nil => Nil
  case pivot :: tail =>
    val(smaller, rest) = tail.partition(_ < pivot)
    qsort(smaller) ::: pivot :: qsort(rest)
}

静态类型

Scala具备类型系统,通过编译时检查,保证代码的安全性和一致性。类型系统具体支持以下特性:

  • 泛型类别,

  • 协变和逆变,

  • 标注,

  • 类型参数的上下限约束,

  • 把类别和抽象类型作为对象成员,

  • 复合类型,

  • 引用自己时显式指定类型,

  • 视图,

  • 多态方法。

擴展性

Scala的設計秉承一項事實,即在實踐中,某個領域特定的應用程式開發往往需要特定於該領域的語言擴展。 Scala提供了許多獨特的語言機制,可以以庫的形式輕易無縫添加新的語言結構:

  • 任何方法可用作前綴或後綴操作符,

  • 可以根據預期型別自動建構閉包。

合併使用以上兩個特性,讓你可以定義新的語句而無須擴充語法也無須使用巨集之類的元程式設計特性。

並發性

Scala使用Actor作為其並發性模型,Actor是類似執行緒的實體,透過郵件匣發送訊息。 Actor可以重複使用線程,因此可以在程式中可以使用數百萬個Actor,而線程只能創建數千個。在2.10之後的版本中,使用Akka作為其預設Actor實作。 [20] 以下程式碼是使用Actor模式的EchoServer實作

val echoServer = actor(new Act {
  become {
    case msg => println("echo " + msg)
  }
})
echoServer ! "hi"

Actor模式可以簡化並發編程,好利用多核心CPU的能力。

本Scala教學手冊涵蓋的內容

本Scala教學涵蓋所有Scala基礎和進階知識,包含了Scala基礎語法、Scala資料型別、Scala變數、Scala運算子、Scala函式、 Scala字串、Scala類別和物件等等所有Scala初步高級知識介紹。

提示:本教學的每一章都包含了許多Scala實例,您可以直接點擊 "執行實例" 按鈕線上查看結果。這些範例將幫助您更好地理解和運用Scala。


#

最新章節


Scala 文件 I/O 2016-10-18
Scala 提取器(Extractor) 2016-10-18
Scala 异常处理 2016-10-18
Scala 正则表达式 2016-10-18
Scala 模式匹配 2016-10-18
Scala Trait(特征) 2016-10-18
Scala 类和对象 2016-10-18
Scala Iterator(迭代器) 2016-10-18