1.初識scala

簡介

??Scala(Scala Language的簡稱)語言是一種能夠運行于JVM和.Net平臺之上的通用編程語言,既可用于大規(guī)模應(yīng)用程序開發(fā)辅斟,也可用于腳本編程转晰。

??Scala由Martin Odersk于2001開發(fā),2004年開始程序運行在JVM與.Net平臺之上士飒,由于其簡潔查邢、優(yōu)雅、類型安全的編程模式而受到關(guān)注酵幕。

Scala創(chuàng)始人——Martin Odersk.jpg

??在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)鍵字

關(guān)鍵字.png

注釋

??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  
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末茎杂,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子纫雁,更是在濱河造成了極大的恐慌煌往,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,348評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件轧邪,死亡現(xiàn)場離奇詭異刽脖,居然都是意外死亡,警方通過查閱死者的電腦和手機闲勺,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,122評論 2 385
  • 文/潘曉璐 我一進店門曾棕,熙熙樓的掌柜王于貴愁眉苦臉地迎上來扣猫,“玉大人菜循,你說我怎么就攤上這事∩暧龋” “怎么了癌幕?”我有些...
    開封第一講書人閱讀 156,936評論 0 347
  • 文/不壞的土叔 我叫張陵,是天一觀的道長昧穿。 經(jīng)常有香客問我勺远,道長,這世上最難降的妖魔是什么时鸵? 我笑而不...
    開封第一講書人閱讀 56,427評論 1 283
  • 正文 為了忘掉前任胶逢,我火速辦了婚禮,結(jié)果婚禮上饰潜,老公的妹妹穿的比我還像新娘初坠。我一直安慰自己,他們只是感情好彭雾,可當(dāng)我...
    茶點故事閱讀 65,467評論 6 385
  • 文/花漫 我一把揭開白布碟刺。 她就那樣靜靜地躺著,像睡著了一般薯酝。 火紅的嫁衣襯著肌膚如雪半沽。 梳的紋絲不亂的頭發(fā)上爽柒,一...
    開封第一講書人閱讀 49,785評論 1 290
  • 那天,我揣著相機與錄音者填,去河邊找鬼浩村。 笑死,一個胖子當(dāng)著我的面吹牛占哟,可吹牛的內(nèi)容都是我干的穴亏。 我是一名探鬼主播,決...
    沈念sama閱讀 38,931評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼重挑,長吁一口氣:“原來是場噩夢啊……” “哼嗓化!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起谬哀,我...
    開封第一講書人閱讀 37,696評論 0 266
  • 序言:老撾萬榮一對情侶失蹤刺覆,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后史煎,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體谦屑,經(jīng)...
    沈念sama閱讀 44,141評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,483評論 2 327
  • 正文 我和宋清朗相戀三年篇梭,在試婚紗的時候發(fā)現(xiàn)自己被綠了氢橙。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,625評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡恬偷,死狀恐怖悍手,靈堂內(nèi)的尸體忽然破棺而出蔫骂,到底是詐尸還是另有隱情乍赫,我是刑警寧澤,帶...
    沈念sama閱讀 34,291評論 4 329
  • 正文 年R本政府宣布火架,位于F島的核電站诡延,受9級特大地震影響滞欠,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜肆良,卻給世界環(huán)境...
    茶點故事閱讀 39,892評論 3 312
  • 文/蒙蒙 一筛璧、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧惹恃,春花似錦夭谤、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,741評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春采蚀,著一層夾襖步出監(jiān)牢的瞬間疲牵,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評論 1 265
  • 我被黑心中介騙來泰國打工榆鼠, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留纲爸,地道東北人。 一個月前我還...
    沈念sama閱讀 46,324評論 2 360
  • 正文 我出身青樓妆够,卻偏偏與公主長得像识啦,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子神妹,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,492評論 2 348

推薦閱讀更多精彩內(nèi)容

  • Scala與Java的關(guān)系 Scala與Java的關(guān)系是非常緊密的M窍! 因為Scala是基于Java虛擬機鸵荠,也就是...
    燈火gg閱讀 3,424評論 1 24
  • 這篇并沒有寫成教程形式的冕茅,只是單純地做學(xué)習(xí)筆記。 2016\\11\\04: 完全看不懂蛹找,奇特而神奇的語言…… 1...
    青禾ws閱讀 388評論 1 1
  • 我最快樂的幾年庸疾,便是我從大學(xué)乍楚,至工作后的那三四年罷。大學(xué)當(dāng)中届慈,無所事事徒溪,工作之后,滿懷憧憬與期待的奮發(fā)向上拧篮,快樂的...
    你不知道的地方閱讀 291評論 0 0