簡介
??Scala(Scala Language的簡稱)語言是一種能夠運行于JVM和.Net平臺之上的通用編程語言,既可用于大規(guī)模應(yīng)用程序開發(fā)辅斟,也可用于腳本編程转晰。
??Scala由Martin Odersk于2001開發(fā),2004年開始程序運行在JVM與.Net平臺之上士飒,由于其簡潔查邢、優(yōu)雅、類型安全的編程模式而受到關(guān)注酵幕。
??在Scala的創(chuàng)建之初扰藕,并沒有怎么引起重視。隨著Apache Spark和Apache Kafka這樣基于Scala的大數(shù)據(jù)框架的崛起芳撒,Scala逐步映入大數(shù)據(jù)從業(yè)者的眼簾邓深。Scala的擁護者們認為Scala的主要優(yōu)勢是速度和它的表達性他嫡。
??目前使用scala的作為支撐公司開發(fā)語言的包括Foursquare和Twitter。2009年Twitter把大部分后臺系統(tǒng)的開發(fā)語言從Ruby換成了Scala庐完。
特性
面向?qū)ο?/h3>
??scala是一種純面向?qū)ο蟮恼Z言钢属,每個值都是對象。對象的數(shù)據(jù)類型以及行為由類和特質(zhì)描述门躯。
函數(shù)式編程
??Scala是一種函數(shù)式語言淆党,其函數(shù)也能當(dāng)成值來使用。Scala提供了輕量級的語法用以定義匿名函數(shù)讶凉,支持高階函數(shù)染乌,允許嵌套多層函數(shù),并支持柯里化懂讯。
靜態(tài)類型
??Scala具備類型系統(tǒng)荷憋,通過編譯時檢查,保證代碼的安全性和一致性褐望。類型系統(tǒng)具體支持以下特性:
- 泛型類
- 協(xié)變和逆變
- 標(biāo)注
- 類型參數(shù)的上下限約束
- 把類別和抽象類型作為對象成員
- 復(fù)合類型
- 引用自己時顯式指定類型
- 視圖
- 多態(tài)方法
擴展性
??Scala提供了許多獨特的語言機制勒庄,可以以庫的形式輕易無縫添加新的語言結(jié)構(gòu):
- 任何方法可用作前綴或后綴操作符
- 可以根據(jù)預(yù)期類型自動構(gòu)造閉包
并發(fā)性
??Scala使用Actor作為其并發(fā)模型,Actor是類似線程的實體瘫里,通過郵箱發(fā)收消息实蔽。
??Actor可以復(fù)用線程,因此可以在程序中可以使用數(shù)百萬個Actor,而線程只能創(chuàng)建數(shù)千個谨读。在2.10之后的版本中局装,使用Akka作為其默認Actor實現(xiàn)。
編程方式
交互式編程
??交互式編程不需要創(chuàng)建腳本文件劳殖,可以通過以下命令調(diào)用铐尚。
$ 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>
腳本形式
?創(chuàng)建一個 HelloWorld.scala 的文件來執(zhí)行代碼
object HelloWorld {
/* 這是我的第一個 Scala 程序
* 以下程序?qū)⑤敵?Hello World!'
*/
def main(args: Array[String]) {
println("Hello, world!") // 輸出 Hello World
}
}
接下來我們使用 scalac 命令編譯它:
$ scalac HelloWorld.scala
$ ls
HelloWorld$.class HelloWorld.scala
HelloWorld.class
使用以下命令來執(zhí)行程序
$ scala HelloWorld
Hello, world!
基本語法
區(qū)分大小寫:Scala是大小寫敏感的,這意味著標(biāo)識Hello 和 hello在Scala中會有不同的含義哆姻。
類名:對于所有的類名的第一個字母要大寫宣增。如果需要使用幾個單詞來構(gòu)成一個類的名稱,每個單詞的第一個字母要大寫填具。示例:class MyFirstScalaClass
方法名稱:所有的方法名稱的第一個字母用小寫统舀。如果若干單詞被用于構(gòu)成方法的名稱,則每個單詞的第一個字母應(yīng)大寫劳景。示例:def myMethodName()
def main(args: Array[String]):Scala程序從main()方法開始處理誉简,這是每一個Scala程序的強制程序入口部分。
關(guān)鍵字
注釋
??Scala 類似 Java 支持單行和多行注釋盟广。多行注釋可以嵌套闷串,但必須正確嵌套,一個注釋開始符號對應(yīng)一個結(jié)束符號筋量。注釋在 Scala 編譯中會被忽略烹吵,實例如下:
object HelloWorld {
/* 這是一個 Scala 程序
* 這是一行注釋
* 這里演示了多行注釋
*/
def main(args: Array[String]) {
// 輸出 Hello World
// 這是一個單行注釋
println("Hello, world!")
}
}
變量
??Scala中碉熄,使用關(guān)鍵詞"var"聲明變量,使用關(guān)鍵詞 "val"聲明常量肋拔。
val myVar : String = "Foo"
var myVar : String = "Too"
??在 Scala 中聲明變量和常量不一定要指明數(shù)據(jù)類型锈津,在沒有指明數(shù)據(jù)類型的情況下,其數(shù)據(jù)類型是通過變量或常量的初始值推斷出來的凉蜂。
??所以琼梆,如果在沒有指明數(shù)據(jù)類型的情況下聲明變量或常量必須要給出其初始值,否則將會報錯窿吩。
var myVar = 10;
val myVal = "Hello, Scala!";
聲明多個變量
// xmax, ymax都聲明為100
val xmax, ymax = 100