/* 下面是介绍Optional Chaining 和 Nil-Coalesce */// Optional Chaining (可选链)if let errorMessage = errorMessage { errorMessage.uppercaseString}// 这种写法完全等价于上面的写法, 当errorMessage有的时候, 才会去执行"?"后面的代码, 否则就终止与"?"// 并且会返回nilerrorMessage?.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一开始并没有赋值, 在赋值之前对其进行使用, 会出现错误, 就有了方式2let message: Stringif 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"