/* 下面是介绍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"