Scala(Scala Language的簡稱)語言是一種能夠運行于JVM和.Net平臺之上的通用編程語言,既可用于大規模應用程序開發,也可用于腳本編程。
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提供了許多獨特的語言機制,可以以庫的形式輕易無縫添加新的語言結構:
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
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。