1. 强解包和?? 运算符来解决可选值的判断
let url = URL(string: "http://www.baidu.com")
// 通过快速推倒(option + 鼠标左键): 可以知道, url为 let url: URL? 可选值类型, 因为这个url可能初始化成功, 但是也可能失败.
// 创建请求 -- 这里创建请求的参数, 为一个必选值, 而url是一个可选值, 所以就会报错, 这里谈两种简单的解决方式(在之前可选值那课有明确的解释):
// 1. 强行解包 -- 格式就是在常量或者变量后面加一个叹号. 作用就是保证参数不为nil, 一定有值, 你就放心使用吧! 但是,一旦你保证错误, 程序也会崩溃(例如: 将上面的网址字符串后面乱写点字母, 就会实例化不成功, 就算这里强行解包了, 走到下一步也会造成崩溃).
let request = URLRequest(url: url!)
// 2. ?? 运算符 -- 格式: 可选值 ?? 程序员自己设定的值. 作用就是一旦可选值为nil的时候, 就会将该可选值赋值为程序员设定的默认值, 这样就不会造成了程序崩溃.
let url2 = url ?? URL(string: "http://www.baidu.com")!
let request = URLRequest(url: url2)
2.if - let/var
- 使用if - let 判断可选值是否为nil
- 定义一个 常量/变量 记录可选值不为nil的结果 在if - let作用域中 直接使用定义好的常量即可.
2.1 判断单个可选值
func demo(){
// if - let/var 判断单个可选值
let url = URL(string: "http://www.baidu.com")
if let u = url {
// 使用新的常量 u 来记录 可选值url不为nil的情况, 当 u 存在, 也就证明url有值, 也就进入到if - let作用域
let request = URLRequest(url: u)
print(request)
}
// 不仅判断url 有值, 且包含"baidu"
if let u = url, u.absoluteString.contains("baidu"){
// 这里的逗号分隔判断, 相当于OC 的 &&, 必须同时满足条件, 才能进入到if - let作用域
let request = URLRequest(url: u)
print(request)
}
}
2.1 判断多个可选值
func demo(){
// if - let/var 判断多个可选值
let name: String? = "老王"
let age: Int? = 18
if var n = name, let a = age{
// 判断多个可选值的时候也是使用逗号分隔开即可
// 在作用域内部需要修改名字的时候, 就需要将let -> var, 不对age进行修改, 就还是用let
n = "老李"
print(n, a)
}
}
3. guard (守护) - let/var
- guard 定义一个常量有值, 如果没有值 也就是为nil 直接return.
- 如果有值 不为nil 代码继续向下进行.
- 判断方式与if-let相反.
- Swift2.0提出的,少了一层代码嵌套.
3.1 guard 判断单个可选值
func demo(){
let url = URL(string: "http://www.baidu.com")
// 单个可选值判断
// 定义一个常量 u 不为nil, 否则 进入 guard 作用域
guard let u = url else {
// 为nil, 直接return
return
}
// 不为nil, 之后所有用到url的操作, 都使用记录的b常量 u 代替
let request = URLRequest(url: u)
print(request)
}
3.2 guard 判断多个可选值
更新
: 判断多个可选值的逗号相当于oc中的 || (或者), 也就是只要有一个值为nil, 就会进入guard (守护) - let/var作用域return掉.
func demo(){
let name: String? = "老王"
let age: Int? = 18
#更新`: 这里的逗号相当于oc中的 || (或者), 也就是只要有一个值为nil, 就会进入guard (守护) - let/var作用域return掉.
guard let n = name, let a = age else {
return
}
print(n, a)
}
最后, 以上内容如有问题, 欢迎指正, 或者有其他的问题, 也欢迎留言讨论~