1. 可选绑定
使用可选绑定(optional binding)来判断可选类型是否包含值,如果包含就把值赋给一个临时常量或者变量。可选绑定可以用在 if 和 while 语句中。
if let constantName = someOptional {
statements
}
//someOptional:指某个可选类型
//如果这个可选类型有值,就将值赋给constantName并执行statements语句。
例子:
if let actualNumber = Int(possibleNumber) {
print("\'\(possibleNumber)\' has an integer value of \(actualNumber)")
} else {
print("\'\(possibleNumber)\' could not be converted to an integer")
}
// possibleNumber已经有值,为‘123’
// Int(possibleNumber)为可选类型Int
// 输出 "'123' has an integer value of 123"
可以包含多个可选绑定或多个布尔条件在一个 if 语句中,只要使用逗号分开就行。
☆可选类型暗示了常量或者变量可以“没有值”。可选可以通过 if 语句来判断是否有值,如果有值的话可以通过可选绑定来解析值。
2. 隐式解析可选类型
当可选类型被第一次赋值之后就可以确定之后一直有值的时候,这种类型的可选状态被定义为隐式解析可选类型(implicitly unwrapped optionals)。
可选的类型的后面的问号(String?)改成感叹号(String!)来声明一个隐式解析可选类型。
☆一个隐式解析可选类型其实就是一个普通的可选类型,但是可以被当做非可选类型来使用,并不需要每次都使用解析来获取可选值。
区别:
let possibleString: String? = "An optional string."
let forcedString: String = possibleString! // 需要感叹号来获取值
let assumedString: String! = "An implicitly unwrapped optional string."
let implicitString: String = assumedString // 不需要感叹号
注意:
如果你在隐式解析可选类型没有值的时候尝试取值,会触发运行时错误。
如果一个变量之后可能变成nil的话请不要使用隐式解析可选类型。如果你需要在变量的生命周期中判断是否是nil的话,请使用普通可选类型。
3.错误处理
当一个函数遇到错误条件,它能报错。调用函数的地方能抛出错误消息并合理处理。
func canThrowAnError() throws {
// 这个函数有可能抛出错误
}
一个函数可以通过在声明中添加throws关键词来抛出错误消息。当你的函数能抛出错误消息时, 你应该在表达式中前置try关键词。
do {
try canThrowAnError()
// 没有错误消息抛出
} catch {
// 有一个错误消息抛出
}
一个do语句创建了一个新的包含作用域,使得错误能被传播到一个或多个catch从句。
4.断言
(1)在某些情况下,如果值缺失或者值并不满足特定的条件,你的代码可能没办法继续执行。这时,你可以在你的代码中触发一个 断言(assertion) 来结束代码运行并通过调试来找到值缺失的原因。
(2)如果条件判断为 true,代码运行会继续进行;如果条件判断为 false,代码执行结束,你的应用被终止。
(3)可以使用全局 assert(::file:line:) 函数来写一个断言。
例子:
let age = -3
assert(age >= 0, "A person's age cannot be less than zero")
//当结果为 false,断言被触发,终止应用。因为 age < 0,所以断言会触发
//如果不需要断言信息,可以省略,即为:assert(age >= 0)
断言的适用情景:
- 整数类型的下标索引被传入一个自定义下标实现,但是下标索引值可能太小或者太大。
- 需要给函数传入一个值,但是非法的值可能导致函数不能正常执行。
- 一个可选值现在是 nil,但是后面的代码运行需要一个非 nil 值。