if
- Swift 中沒(méi)有C語(yǔ)言中 非零即真 的概念
- 在邏輯判斷時(shí)必須顯式的指明具體的判斷條件
true/false
- if 語(yǔ)句條件的()可以省略
- 但是
{}
不能省略
let num = 200
if num < 10 {
print("比 10 小")
} else if num > 100 {
print("比 100 大")
} else {
print("10 ~ 100 之間的數(shù)字")
}
三目運(yùn)算符
- Swift 中的三目運(yùn)算符保持了與OC一致的風(fēng)格
var a = 10
var b = 20
let c = a > b ? a : b
print(c)
適當(dāng)?shù)倪\(yùn)用三目運(yùn)算符有咨,能夠讓代碼寫(xiě)的更加簡(jiǎn)潔。
可選項(xiàng)判斷
- 由于可選項(xiàng)的內(nèi)容可能為 nil,而一旦為 nil 則不允許參與計(jì)算
- 因此 在實(shí)際開(kāi)發(fā)中,經(jīng)常需要判斷可選項(xiàng)的內(nèi)容是否為 nil
單個(gè)可選項(xiàng)判斷
let url = NSUrl(string:"http://www.baidu.com")
//方法1:強(qiáng)行解包 - 缺陷,如果 url 為空熊赖,運(yùn)行時(shí)會(huì)崩潰
let request = NSURLRequest(URL:url!)
//方法2:首先判斷 - 代碼中仍然需要使用`!`強(qiáng)行解包 但是不會(huì)造成crash
if url != nil {
let request = NSURLRequest(URL:url!)
}
//方法3:使用 `if let`,這種方式,表明一旦進(jìn)入 if 分支刊愚, u 就不再是可選項(xiàng)
if let u = url where u.host == "www.baidu.com" {
let request = NSURLRequest(URL:u)
}
可選項(xiàng)條件判斷
//1>當(dāng)判斷需要增加條件的時(shí)候弟头,若使用if的嵌套 吩抓,則會(huì)使代碼復(fù)雜冗余
if let u = url{
if u.host == "www.baidu.com" {
let request = NSURLRequest(URL: u)
}
}
//2>使用where關(guān)鍵字
if let u = url where u.host == "www.baidu.com" {
let request = NSURLRequest(URL: u)
}
- 總結(jié)
-
if let
不能使用 && 、||等條件判斷 - 如果要增加判斷條件亮瓷, 可以使用 where 子句
- 注意: where 子句沒(méi)有智能提示
-
多個(gè)可選項(xiàng)判斷
//可以使用`,`同時(shí)判斷多個(gè)可選項(xiàng)是否為空
let tName:String? = "zhangsan"
let tNO:Int? = 29
if let name = tName {
if let no = tNo {
print("姓名:" + name + "學(xué)號(hào):" + String(no))
}
}
if let name = tName, let no = tNo {
print("姓名:" + name + "學(xué)號(hào):" + String(no))
}
判斷之后對(duì)變量需要修改
let tName:String? = "張三"
let tNo:Int? = 19
if var name = tName, no = tNo {
name = "李四"
no = 1
print("姓名:" + name + "學(xué)號(hào):" + String(no))
}
guard
- guard 是與
if let
相反的語(yǔ)法琴拧, Swift 2.0 推出
let tName:String? = "zhangsan"
let tNo:Int? = 9
guard let name = tName else {
print("name為空")
retuen
}
guard let no = tNo else {
print("no為空")
return
}
//代碼如果能執(zhí)行至此, name & no 都肯定是有值的
print(name)
print(no)
- 在程序編寫(xiě)時(shí)嘱支, 條件檢測(cè)之后的代碼是相對(duì)復(fù)雜的
- 使用 guard 的好處
- 能夠判斷每一個(gè)值
- 在真正的代碼邏輯部分蚓胸,省略了一層嵌套
switch
- switch 不再局限于整數(shù)
- switch 可以針對(duì)任意數(shù)據(jù)類(lèi)型進(jìn)行判斷
- 不再需要 break
- 每一個(gè) case 后面必須有可以執(zhí)行的語(yǔ)句
- 要保證處理所有可能的情況, 不然編譯器直接報(bào)錯(cuò)除师, 不處理的條件可以放在 default 分支中
- 每個(gè) case 中定義的變量?jī)H在 當(dāng)前 case 中有效沛膳, 而OC中需要使用
{}
let score = "優(yōu)"
switch score {
case "優(yōu)":
let name = "張三"
print(name + "80~100分")
case "良": print("70~80")
case "中": print("60~70")
case "差": print("不及格")
default: break
}
- switch 中同樣能夠賦值和使用 where 子句
let point = CGPoint(x: 10, y: 10)
switch point {
case let p where p.x == 0 && p.y == 0:
print("中心點(diǎn)")
case let p where p.x == 0:
print("Y軸")
case let p where p.y == 0:
print("X軸")
case let p abs(p.x) == abs(p.y):
print("對(duì)角線(xiàn)")
default:
print("其他")
}
- 如果只希望進(jìn)行條件判斷,賦值部分可以省略
switch score{
case _ where score > 80:
print("優(yōu)")
case _ where score > 60:
print("及格")
default:
print("其他")
}