Scala(Scala Language的簡稱)語言是一種可以運行於JVM和.Net平臺之上的通用編程語言,既可用於大規模應用程序開發,也可用於腳本編程。express
Scala由Martin Odersk於2001開發,2004年開始程序運行在JVM與.Net平臺之上,因爲其簡潔、優雅、類型安全的編程模式而受到關注。 編程
在Scala的建立之初,並無怎麼引發重視。隨着Apache Spark和Apache Kafka這樣基於Scala的大數據框架的崛起,Scala逐步映入大數據從業者的眼簾。Scala的擁護者們認爲Scala的主要優點是速度和它的表達性。安全
目前使用scala的做爲支撐公司開發語言的包括Foursquare和Twitter。2009年Twitter把大部分後臺系統的開發語言從Ruby換成了Scala。閉包
scala是一種純面向對象的語言,每一個值都是對象。對象的數據類型以及行爲由類和特質描述。併發
Scala是一種函數式語言,其函數也能當成值來使用。Scala提供了輕量級的語法用以定義匿名函數,支持高階函數,容許嵌套多層函數,並支持柯里化。框架
Scala具有類型系統,經過編譯時檢查,保證代碼的安全性和一致性。類型系統具體支持如下特性:編程語言
Scala提供了許多獨特的語言機制,能夠以庫的形式輕易無縫添加新的語言結構:ide
Scala使用Actor做爲其併發模型,Actor是相似線程的實體,經過郵箱發收消息。函數式編程
Actor能夠複用線程,所以能夠在程序中可使用數百萬個Actor,而線程只能建立數千個。在2.10以後的版本中,使用Akka做爲其默認Actor實現。函數
交互式編程不須要建立腳本文件,能夠經過如下命令調用。
$ scala Welcome to Scala version 2.11.7 (Java HotSpot(TM) 64-Bit Server VM, Java 1.8.0_31). Type in expressions to have them evaluated. Type :help for more information. scala> 1 + 1 res0: Int = 2 scala> println("Hello World!") Hello World! scala>
建立一個 HelloWorld.scala 的文件來執行代碼
object HelloWorld { /* 這是個人第一個 Scala 程序 * 如下程序將輸出'Hello World!' */ def main(args: Array[String]) { println("Hello, world!") // 輸出 Hello World } }
接下來咱們使用 scalac 命令編譯它:
$ scalac HelloWorld.scala $ ls HelloWorld$.class HelloWorld.scala HelloWorld.class
使用如下命令來執行程序
$ scala HelloWorld Hello, world!
區分大小寫:Scala是大小寫敏感的,這意味着標識Hello 和 hello在Scala中會有不一樣的含義。
類名:對於全部的類名的第一個字母要大寫。若是須要使用幾個單詞來構成一個類的名稱,每一個單詞的第一個字母要大寫。示例:class MyFirstScalaClass
方法名稱:全部的方法名稱的第一個字母用小寫。若是若干單詞被用於構成方法的名稱,則每一個單詞的第一個字母應大寫。示例:def myMethodName()
Scala 相似 Java 支持單行和多行註釋。多行註釋能夠嵌套,但必須正確嵌套,一個註釋開始符號對應一個結束符號。註釋在 Scala 編譯中會被忽略,實例以下:
object HelloWorld { /* 這是一個 Scala 程序 * 這是一行註釋 * 這裏演示了多行註釋 */ def main(args: Array[String]) { // 輸出 Hello World // 這是一個單行註釋 println("Hello, world!") } }
Scala中,使用關鍵詞"var"聲明變量,使用關鍵詞 "val"聲明常量。
val myVar : String = "Foo" var myVar : String = "Too"
在 Scala 中聲明變量和常量不必定要指明數據類型,在沒有指明數據類型的狀況下,其數據類型是經過變量或常量的初始值推斷出來的。
因此,若是在沒有指明數據類型的狀況下聲明變量或常量必需要給出其初始值,不然將會報錯。
var myVar = 10; val myVal = "Hello, Scala!";
聲明多個變量
// xmax, ymax都聲明爲100 val xmax, ymax = 100