- 變量聲明
- 條件表達(dá)式
- 塊表達(dá)式
- 循環(huán)
- 方法和函數(shù)
- 元組
1. 變量聲明
定義變量用關(guān)鍵字 var
或 val
val
定義的變量是不可變的,相當(dāng)于java中的final;推薦使用 val
var
定義的變量是可變的;
lazy
表示延遲加載,并且不能修飾 var
變量
定義變量時(shí),必須賦予初始值,如果沒(méi)有初始值,使用通配符 _
且必須指定類(lèi)型
2. 條件表達(dá)式
類(lèi)似于java,但表達(dá)式都有返回值,
val k = if (x < 0) 0 else if (x >= 1) 1 else -1
3. 塊表達(dá)式
{ }
稱為塊表達(dá)式糖儡,塊表達(dá)式中可以包含一系列的表達(dá)式循捺,最后一個(gè)表達(dá)式的值就是塊的值。
val result = {
if (x < 0){
-1
} else if(x >= 1) {
1
} else {
"error"
}
}
4. 循環(huán)
循環(huán)有 for
循環(huán)和 while
循環(huán)兩種,for循環(huán)最常用
4.1 for循環(huán)
for (item <- arr) {println(item)} //類(lèi)似java中的增強(qiáng)for
for (i <- 1 to 6){ } // [1,6]區(qū)間包含6
for(i <- 1 until 6) { } //[1,6)區(qū)間不包含6
for(e <- arr if e % 2 == 0) { } //可增加條件判斷
for(i <- 1 to 3; j <- 1 to 3 if i != j){ } //嵌套循環(huán)
val v = for (i <- 1 to 10) yield i * 10 //yield表示生成新的集合
4.2 while循環(huán)
while的返回值都為Unit
while(condition){ 循環(huán)體內(nèi)容 }
do{ 循環(huán)體內(nèi)容 }while(condition)
5. 方法和函數(shù)
方法定義:
def methodName(param1:Int,param2:Int):Int=param1*param2 //常規(guī)方法
def sumAll(b: Int*): Int = { for (i<- b){ v += i }} //*表示參數(shù)可變
def sayHello1 = println("Say BB1") // 方法沒(méi)有參數(shù), 也沒(méi)有返回值
def sayHello2() = println("Say BB2")
sayHello1 // 如果方法沒(méi)有() 調(diào)用時(shí)不能加()
sayHello2 // 可省略(), 也可以不省略
def rec(n:Int):Int= if (n==0) 0 else n*rec(n-1) //遞歸方法必須指定返回類(lèi)型
def meth1(x:Int,y:Double):Double = return x*y //含return必須指定返回類(lèi)型
函數(shù)定義:
val| var 函數(shù)名稱=(函數(shù)的參數(shù)列表) => 函數(shù)體
var func=(x:Int,y:Int) => x*y
val | var 函數(shù)名稱:(輸入?yún)?shù)類(lèi)型)=> 返回值類(lèi)型 = (參數(shù)的引用)=> 函數(shù)體
var func:(x:Int,y:Int) => Int ={ x*y }
函數(shù)和方法的聯(lián)系:
1.函數(shù)和變量洋访,類(lèi),對(duì)象,一個(gè)級(jí)別; 方法孤里,要?dú)w屬于類(lèi)或者對(duì)象
2.函數(shù)可以作為方法的參數(shù),和返回值類(lèi)型
def m(f:(Int,Int)=>Int)=f(1,2)
def f(x:Int,y:Int)=x+y
m(f)
3.方法可以轉(zhuǎn)換成函數(shù)
val f=m _ //在方法后面加下劃線可轉(zhuǎn)為函數(shù)
6. 元組
定義:元組就是不同類(lèi)型元素的集合,元組不可變
6.1 創(chuàng)建與獲取
val t = (12.3, 1000, "spark")
val t4 = new Tuple4(1,2.0,"",3) // 必須4個(gè)元素
val ele=t._1 //使用下劃線下標(biāo)可以獲取, 下標(biāo)從1開(kāi)始
6.2 元組的一些方法
Array(("tom",11),("lisa",88)).toMap //對(duì)偶的集合可以轉(zhuǎn)換成map
Array("xx1","xx2","xx3").zip(Array(1,2,3)) //Array(("xx1",1),("xxx2",2),("xxx3",3)) //多值綁定,生成元組集合
("xx1",1).swap //返回(1,"xx1"),交換對(duì)偶元組
t.productIterator.foreach(println) //迭代元組