/* 下面是介绍Optional Chaining 和 Nil-Coalesce */

// Optional Chaining (可选链)
if let errorMessage = errorMessage {
errorMessage.uppercaseString
}
// 这种写法完全等价于上面的写法, 当errorMessage有的时候, 才会去执行"?"后面的代码, 否则就终止与"?"
// 并且会返回nil
errorMessage?.uppercaseString
// 这种写法也可以, 但和上面的写法表示的意思完全不一样, 表示解包后就是一个字符串, 然后执行"!"后的代码
// 一样存在风险(当errorMessage为nil时, 就会报错)
errorMessage!.uppercaseString // 另外一个可选值调用方法或者访问属性返回的是可选值, 可以使用可选链来达到精简代码的目的, 例如
errorMessage?.stringByRemovingPercentEncoding?.stringByRemovingPercentEncoding // 这里的newErrorMessage并没有显式声明为可选型变量, 但由于errorMessage?.uppercaseString可能返回nil
// Swift就认为newErrorMessage必须是一个可选型变量
let newErrorMessage = errorMessage?.capitalizedString // 所以也可以这样进行解包操作
if let newErrorMessage = errorMessage?.capitalizedString {
print(newErrorMessage)
} // Nil-Coalesce
// 方式1: 由于message一开始并没有赋值, 在赋值之前对其进行使用, 会出现错误, 就有了方式2
let message: String
if let newErrorMessage = newErrorMessage {
message = newErrorMessage
} else {
message = "No Error"
}
print(message) // 方式2: 三目运算
let message2: String = newErrorMessage != nil ? newErrorMessage! : "No Error" // 方式3: 更简洁 (表示, 如果newErrorMessage的值为nil, 就赋值为??后面的值, 否则就把newErrorMessage解包后的值进行赋值)
let message3 = newErrorMessage ?? "No Error"

  

04-16 13:09