Scala學習筆記(三)

Scala的基礎語法

繼上一篇的基礎語法之后,我又整理了一些個人學習過程中認為比較重要的語法。

1. if/else 表達式

1.1 替代三目運算符

先用 Java 來寫一段三目運算符的代碼

int i = 10;
int j = i>5?i:5

Scala 由于沒有 Java 的三目運算符(?:),不過好在可以用 if/else 表達式替代它。

scala> val i = 10
i: Int = 10

scala> val j = if (i>5) i else 5
j: Int = 10

上面的代碼,還可以寫成

scala> val i = 10
i: Int = 10

scala> var j =0
j: Int = 0

scala> if (i>5) j = i else j=5

scala> println (j)
10

不過,這種寫法變量 j 需要定義成 var,因為 val 的變量一旦定義不能被改變略嫌麻煩 , 所以第一種寫法會更好。

1.2 混合類型表達式

scala> val i = 10
i: Int = 10

scala> val j = if (i>5) "String express" else 5
j: Any = String express

scala> println(j)
String express

一般三目運算符肯定是返回同一種類型,但是上述的代碼在 if 和 else 里既有String類型又有Int類型。所以,返回的是兩個類型的公共超類型Any。

2. 占位符_

Scala 可以把下劃線“_”當做一個或多個參數的占位符,第一個下劃線代表第一個參數,第二個下劃線代表第二個,以此類推。只要每個參數在函數文本內僅出現一次。

先看一段 Java 的代碼,它將集合的每個元素都乘以2再打印出來。

Integer[] arrays = {1,2,3,4,5};
List<Integer> list = Arrays.asList(arrays);
list.stream().map(it->it*2).forEach(System.out::println);

再用占位符來簡化上述的 Java 代碼

scala> val list = Array(1,2,3,4,5)
list: Array[Int] = Array(1, 2, 3, 4, 5)

scala> list.map(_*2).foreach(println)
2
4
6
8
10

通過對比,顯然 Scala 的代碼更加簡潔。

再來一個例子:多個占位符

scala> val f1 = (x:Int,y:Int) => x+y
f1: (Int, Int) => Int = $$Lambda$1011/349978505@1706a5c9

scala> f1(1,2)
res0: Int = 3

用兩個占位符來簡化上面的代碼。

scala> val f2 = (_:Int)+(_:Int)
f2: (Int, Int) => Int = $$Lambda$1034/74606989@7b7683d4

scala> f2(1,2)
res1: Int = 3

3. Array 、 ArrayBuffer 以及多維數組

Scala 的數組包括定長數組 Array,以及不定長數組 ArrayBuffer。

3.1 Array

scala> val nums = new Array[Int](10) // 所有元素初始化為0
nums: Array[Int] = Array(0, 0, 0, 0, 0, 0, 0, 0, 0, 0)

scala> val strings = new Array[String](10) // 所有元素初始化為null
strings: Array[String] = Array(null, null, null, null, null, null, null, null, null, null)
scala> val names = Array("tony", "cafei", "aaron")
names: Array[String] = Array(tony, cafei, aaron)

scala> names(0)
res2: String = tony

一旦初始化 Array ,只能修改 Array 中的元素,不能增加或者刪除元素。

3.2 ArrayBuffer

ArrayBuffer類似 Java 中的ArrayList。它是數組緩沖。

scala> import scala.collection.mutable.ArrayBuffer
import scala.collection.mutable.ArrayBuffer

scala> val arrayBuffer = new ArrayBuffer[Int]
arrayBuffer: scala.collection.mutable.ArrayBuffer[Int] = ArrayBuffer()

scala> arrayBuffer += 0
res7: arrayBuffer.type = ArrayBuffer(0)

scala> arrayBuffer += 1
res8: arrayBuffer.type = ArrayBuffer(0, 1)

scala> arrayBuffer += (2,3,4,5)
res9: arrayBuffer.type = ArrayBuffer(0, 1, 2, 3, 4, 5)

scala> arrayBuffer ++= Array(6,7,8,9,10) // 添加Array需要使用++
res10: arrayBuffer.type = ArrayBuffer(0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10)

scala> arrayBuffer.trimEnd(1) // 刪除最后一個元素

scala> println (arrayBuffer)
ArrayBuffer(0, 1, 2, 3, 4, 5, 6, 7, 8, 9)

ArrayBuffer 還支持在任意位置進行添加(insert)和刪除(remove)操作

scala> arrayBuffer.insert(2,100) // 在下標2處插入100

scala> println (arrayBuffer)
ArrayBuffer(0, 1, 100, 2, 3, 4, 5, 6, 7, 8, 9)

scala> arrayBuffer.insert(5,101,102) // 在下標5處插入101,102

scala> println (arrayBuffer)
ArrayBuffer(0, 1, 100, 2, 3, 101, 102, 4, 5, 6, 7, 8, 9)

反之,ArrayBuffer 的 remove 操作是同理。

除此之外, ArrayBuffer 還有 sum、max、min、sorted 等常用函數。

ArrayBuffer 到 Array 的轉換: toArray

scala> arrayBuffer.toArray
res21: Array[Int] = Array(0, 1, 100, 2, 3, 101, 102, 4, 5, 6, 7, 8, 9)

3.3 多維數組

Scala 多維數組是通過數組的數組來實現的。二維數組看起來像是Array[Array[Int]]。要構造這樣一個數組,可以用ofDim方法。

二維數組的定義

scala> val matrix=Array.ofDim[Int](3,4) 
matrix: Array[Array[Int]] = Array(Array(0, 0, 0, 0), Array(0, 0, 0, 0), Array(0, 0, 0, 0))

三維數組的定義

scala> val matrix2 = Array.ofDim[Int](3,4,5)
matrix2: Array[Array[Array[Int]]] = Array(Array(Array(0, 0, 0, 0, 0), Array(0, 0, 0, 0, 0), Array(0, 0, 0, 0, 0), Array(0, 0, 0, 0, 0)), Array(Array(0, 0, 0, 0, 0), Array(0, 0, 0, 0, 0), Array(0, 0, 0, 0, 0), Array(0, 0, 0, 0, 0)), Array(Array(0, 0, 0, 0, 0), Array(0, 0, 0, 0, 0), Array(0, 0, 0, 0, 0), Array(0, 0, 0, 0, 0)))

所以,多維數組的定義:
Array.ofDim[類型](維度1, 維度2, 維度3,....)

4. 不可變Map 和 可變Map

4.1 不可變Map

不可變Map位于scala.collection.immutable包中。

假設,我們定義某學生的期末考試分數,它是一個不可改變的Map集合。

scala> val scores = Map("math"->90,"english"->85,"chinese"->80)
scores: scala.collection.immutable.Map[String,Int] = Map(math -> 90, english -> 85, chinese -> 80)

獲取該學生的數學成績

scala> scores("math")
res8: Int = 90

獲取該學生的計算機成績,其實并沒有錄入計算機課程的分數會出現什么情況呢?

scala> scores("computer")
java.util.NoSuchElementException: key not found: computer
  at scala.collection.immutable.Map$Map3.apply(Map.scala:156)
  ... 30 elided

不出意外地報了一個錯誤。
所以,我們得先判斷一下map里是否包含計算機課程,包含的話就取出成績,不包含的話只能默認0分,這樣代碼才安全。

scala> val computer = if (scores.contains("computer")) scores("computer") else 0
computer: Int = 0

這下,命令行就不會報錯了。

4.2 可變Map

可變Map位于scala.collection.mutable包中。
對于剛才的情況,添加該學生計算機的成績。

scala> scores +=("computer"->88)
<console>:13: error: value += is not a member of scala.collection.immutable.Map[String,Int]
       scores +=("computer"->88)

scala是會報錯的,因為scores是不可變map。

重新定義scores,讓它變成可變的map,這樣就可以添加其他課程的成績了。

scala> val scores = scala.collection.mutable.Map("math"->90,"english"->85,"chinese"->80)
scores: scala.collection.mutable.Map[String,Int] = Map(chinese -> 80, math -> 90, english -> 85)

scala> scores +=("computer"->88)
res12: scores.type = Map(computer -> 88, chinese -> 80, math -> 90, english -> 85)

換一個角度,我們來看看如何定義一個空的Map


scala> val map=new scala.collection.mutable.HashMap[String,Int]()
map: scala.collection.mutable.HashMap[String,Int] = Map()

scala> map += ("computer"->88)
res15: map.type = Map(computer -> 88)

scala> map +=  ("math"->90,"english"->85,"chinese"->80)
res16: map.type = Map(computer -> 88, chinese -> 80, math -> 90, english -> 85)

scala> println (map)
Map(computer -> 88, chinese -> 80, math -> 90, english -> 85)

scala> map.getClass
res18: Class[_ <: scala.collection.mutable.HashMap[String,Int]] = class scala.collection.mutable.HashMap

未來,我會單獨再整理一篇集合相關的文章。

5. 元組

元組(Tuple)是不同類型的值的聚集。

定義一個元組:

scala> val tuple = (0,false,"Scala")
tuple: (Int, Boolean, String) = (0,false,Scala)

然后我們可以用方法_1、_2、_3訪問其元素。

scala> println(tuple._1) // 打印第一個元素
0

scala> println(tuple._2) // 打印第二個元素
false

scala> println(tuple._3) // 打印第三個元素
Scala

值得注意的是,元組的索引是從1開始,而數組的索引是從0開始。

通常,使用模式匹配來獲取元組的元素。

scala> val (first, second, third)=tuple
first: Int = 0
second: Boolean = false
third: String = Scala

如果并不是所有的元素都需要,那么可以在不需要的元素位置上使用占位符_:

scala> val (first, second, _ ) = tuple
first: Int = 0
second: Boolean = false

總結

這篇筆記還是整理一些基礎的知識。

下一篇開始,我會整理 Scala 的類相關的內容。

先前的文章:
Scala學習筆記(二)
Scala學習筆記(一)

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,622評論 6 544
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,716評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,746評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,991評論 1 318
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,706評論 6 413
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 56,036評論 1 329
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 44,029評論 3 450
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 43,203評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,725評論 1 336
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,451評論 3 361
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,677評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,161評論 5 365
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,857評論 3 351
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,266評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,606評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,407評論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,643評論 2 380

推薦閱讀更多精彩內容

  • scala學習筆記 第2章 變量和數據類型 基本數據 scala的核心數據為四種 :字面量、值、變量、類型 值使...
    485b1aca799e閱讀 2,148評論 0 1
  • 數組 :new Array[Int](8)與Array[Int](8)的區別:第一種8個元素,第二個定義一個值為8...
    夙夜M閱讀 1,797評論 1 2
  • Array //聲明變量arr為Array整數類型的數組,包含5個元素。 scala>valarr=newArra...
    flyskyzyl閱讀 5,684評論 0 4
  • Scala的集合類可以從三個維度進行切分: 可變與不可變集合(Immutable and mutable coll...
    時待吾閱讀 5,848評論 0 4
  • 瀏覽器內核可以分為渲染引擎和js引擎。取得網頁內容,整理訊息,計算網頁顯示方式。所有網頁瀏覽器、電子郵件客戶端以及...
    shoutinggg閱讀 457評論 0 0