1.初識(shí)scala

簡(jiǎn)介

??Scala(Scala Language的簡(jiǎn)稱)語(yǔ)言是一種能夠運(yùn)行于JVM和.Net平臺(tái)之上的通用編程語(yǔ)言,既可用于大規(guī)模應(yīng)用程序開(kāi)發(fā),也可用于腳本編程。

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

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

??在Scala的創(chuàng)建之初,并沒(méi)有怎么引起重視。隨著Apache Spark和Apache Kafka這樣基于Scala的大數(shù)據(jù)框架的崛起,Scala逐步映入大數(shù)據(jù)從業(yè)者的眼簾。Scala的擁護(hù)者們認(rèn)為Scala的主要優(yōu)勢(shì)是速度和它的表達(dá)性。

??目前使用scala的作為支撐公司開(kāi)發(fā)語(yǔ)言的包括Foursquare和Twitter。2009年Twitter把大部分后臺(tái)系統(tǒng)的開(kāi)發(fā)語(yǔ)言從Ruby換成了Scala。

特性

面向?qū)ο?/h3>

??scala是一種純面向?qū)ο蟮恼Z(yǔ)言,每個(gè)值都是對(duì)象。對(duì)象的數(shù)據(jù)類型以及行為由類和特質(zhì)描述。

函數(shù)式編程

??Scala是一種函數(shù)式語(yǔ)言,其函數(shù)也能當(dāng)成值來(lái)使用。Scala提供了輕量級(jí)的語(yǔ)法用以定義匿名函數(shù),支持高階函數(shù),允許嵌套多層函數(shù),并支持柯里化。

靜態(tài)類型

??Scala具備類型系統(tǒng),通過(guò)編譯時(shí)檢查,保證代碼的安全性和一致性。類型系統(tǒng)具體支持以下特性:

  • 泛型類
  • 協(xié)變和逆變
  • 標(biāo)注
  • 類型參數(shù)的上下限約束
  • 把類別和抽象類型作為對(duì)象成員
  • 復(fù)合類型
  • 引用自己時(shí)顯式指定類型
  • 視圖
  • 多態(tài)方法

擴(kuò)展性

??Scala提供了許多獨(dú)特的語(yǔ)言機(jī)制,可以以庫(kù)的形式輕易無(wú)縫添加新的語(yǔ)言結(jié)構(gòu):

  • 任何方法可用作前綴或后綴操作符
  • 可以根據(jù)預(yù)期類型自動(dòng)構(gòu)造閉包

并發(fā)性

??Scala使用Actor作為其并發(fā)模型,Actor是類似線程的實(shí)體,通過(guò)郵箱發(fā)收消息。

??Actor可以復(fù)用線程,因此可以在程序中可以使用數(shù)百萬(wàn)個(gè)Actor,而線程只能創(chuàng)建數(shù)千個(gè)。在2.10之后的版本中,使用Akka作為其默認(rèn)Actor實(shí)現(xiàn)。

編程方式

交互式編程

??交互式編程不需要?jiǎng)?chuàng)建腳本文件,可以通過(guò)以下命令調(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)建一個(gè) HelloWorld.scala 的文件來(lái)執(zhí)行代碼

object HelloWorld {
   /* 這是我的第一個(gè) Scala 程序
    * 以下程序?qū)⑤敵?Hello World!' 
    */
   def main(args: Array[String]) {
      println("Hello, world!") // 輸出 Hello World
   }
}

接下來(lái)我們使用 scalac 命令編譯它:

$ scalac HelloWorld.scala 
$ ls
HelloWorld$.class    HelloWorld.scala
HelloWorld.class 

使用以下命令來(lái)執(zhí)行程序

$ scala HelloWorld
Hello, world!

基本語(yǔ)法

  • 區(qū)分大小寫(xiě):Scala是大小寫(xiě)敏感的,這意味著標(biāo)識(shí)Hello 和 hello在Scala中會(huì)有不同的含義。

  • 類名:對(duì)于所有的類名的第一個(gè)字母要大寫(xiě)。如果需要使用幾個(gè)單詞來(lái)構(gòu)成一個(gè)類的名稱,每個(gè)單詞的第一個(gè)字母要大寫(xiě)。示例:class MyFirstScalaClass

  • 方法名稱:所有的方法名稱的第一個(gè)字母用小寫(xiě)。如果若干單詞被用于構(gòu)成方法的名稱,則每個(gè)單詞的第一個(gè)字母應(yīng)大寫(xiě)。示例:def myMethodName()

  • def main(args: Array[String]):Scala程序從main()方法開(kāi)始處理,這是每一個(gè)Scala程序的強(qiáng)制程序入口部分。

關(guān)鍵字

關(guān)鍵字.png

注釋

??Scala 類似 Java 支持單行和多行注釋。多行注釋可以嵌套,但必須正確嵌套,一個(gè)注釋開(kāi)始符號(hào)對(duì)應(yīng)一個(gè)結(jié)束符號(hào)。注釋在 Scala 編譯中會(huì)被忽略,實(shí)例如下:

object HelloWorld {
   /* 這是一個(gè) Scala 程序
    * 這是一行注釋
    * 這里演示了多行注釋
    */
   def main(args: Array[String]) {
      // 輸出 Hello World
      // 這是一個(gè)單行注釋
      println("Hello, world!") 
   }
}

變量

??Scala中,使用關(guān)鍵詞"var"聲明變量,使用關(guān)鍵詞 "val"聲明常量。

val myVar : String = "Foo"
var myVar : String = "Too"

??在 Scala 中聲明變量和常量不一定要指明數(shù)據(jù)類型,在沒(méi)有指明數(shù)據(jù)類型的情況下,其數(shù)據(jù)類型是通過(guò)變量或常量的初始值推斷出來(lái)的。

??所以,如果在沒(méi)有指明數(shù)據(jù)類型的情況下聲明變量或常量必須要給出其初始值,否則將會(huì)報(bào)錯(cuò)。

var myVar = 10;
val myVal = "Hello, Scala!";

聲明多個(gè)變量

// xmax, ymax都聲明為100
val xmax, ymax = 100  
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Scala與Java的關(guān)系 Scala與Java的關(guān)系是非常緊密的??! 因?yàn)镾cala是基于Java虛擬機(jī),也就是...
    燈火gg閱讀 3,608評(píng)論 1 24
  • 這篇并沒(méi)有寫(xiě)成教程形式的,只是單純地做學(xué)習(xí)筆記。 2016\\11\\04: 完全看不懂,奇特而神奇的語(yǔ)言…… 1...
    青禾ws閱讀 417評(píng)論 1 1
  • 我最快樂(lè)的幾年,便是我從大學(xué),至工作后的那三四年罷。大學(xué)當(dāng)中,無(wú)所事事,工作之后,滿懷憧憬與期待的奮發(fā)向上,快樂(lè)的...
    你不知道的地方閱讀 328評(píng)論 0 0

友情鏈接更多精彩內(nèi)容