可选绑定
- 关于optionals
- if 语句以及强制解析
- 选绑定
- 式解析可选
- 误处理
- 断言
关于optionals
可选表示有值 或者 没值
在oc中一个方法要不返回一个对象要不返回一个nil nil表示‘缺少一个合法的对象’ nil只对对象起作用 oc用nil这个特殊值来暗示值得缺失 对于结构体等C的基本类型不起作用 Swift的可选可以让你暗示任意类型的值得缺失情况,并不需要一个特殊的值 例如
let possibleNumber = "123"
let convertedNumber = Int(possibleNumber)
一个
可选的 Int 被写作 Int?而不是 Int。问号暗示包含的值是可选,也就是说可能包含 Int 值也可能不包含值。(不能包含其他任何值比如 Bool 值或者 String 值。只能是 Int 或者什么都没 有。)
if 语句以及强制解析
你可以使用 if 语句来判断一个可选是否包含值。如果可选有值,结果是 true;如果没有值,结果是 false。你可以用‘==’来表示等于 用‘!=’ 表示不等于 代码如下
if convertedNumber != nil {
print ("--------")
}
当你确定可选包确实含值之后,你可以在可选的名字后面加一个感叹号(!)来获取值。这个惊叹号表示“我知道这个可选有值,请使用它。”这被称为可选值的强制解析(forcedunwrapping)
可选绑定
使用可选绑定(optional binding)来判断可选是否包含值,如果包含就把值赋给一个临时
常量或者变量。可选绑定可以用在 if 和 while 语句中来对可选的值进行判断并把值赋给一 个常量或者变量。if 和 while 语句,请参考控制流。
像下面这样在 if 语句中写一个可选绑定:
if let constantName = someOptional {
statements
}
你可以一行代码中包含多个可选值的绑定 用‘where’引起一个bool的判断条件 如果这些绑定可选值中的任何一个是nil 或者条件判断是nil 那么整个可选绑定值就被视为是不成功的
if let firstValue = Int("4"),secondValue = Int("452") where firstValue < secondValue {
print("\(firstValue) < \(secondValue)")
}
你可以给可选变量赋值为 nil 来表示它没有值:
var serverResponseCode: Int? = 404
// serverResponseCode 包含一个可选的 Int 值 404
serverResponseCode = nil
serverResponseCode 现在不包含值
注意:nil 不能用于非可选的常量和变量。如果你的代码中有常量或者变量需要处理值缺失 的情况,请把它们声明成对应的可选类型。
如果你声明一个可选常量或者变量但是没有赋值,它们会自动被设置为 nil:
var surveyAnswer: String?
// surveyAnswer 被自动设置为 nil
隐式解析可选
如上所述,可选暗示了常量或者变量可以“没有值”。可选可以通过 if 语句来判断是否有
值,如果有值的话可以通过可选绑定来解析值。
有时候在程序架构中,第一次被赋值之后,可以确定一个可选总会有值。在这种情况下,
每次都要判断和解析可选值是非常低效的,因为可以确定它总会有值。 这种类型的可选被定义为隐式解析可选(implicitly unwrapped optionals)。把想要用作可 选的类型的后面的问号(String?)改成感叹号(String!)来声明一个隐式解析可选。
当可选被第一次赋值之后就可以确定之后一直有值的时候,隐式解析可选非常有用。隐式 解析可选主要被用在 Swift 中类的构造过程中,请参考类实例之间的循环强引用。
一个隐式解析可选其实就是一个普通的可选,但是可以被当做非可选来使用,并不需要每
次都使用解析来获取可选值。下面的例子展示了可选 String 和隐式解析可选 String 之间的
区别:
1. let possibleString: String? = "An optional string."
2. println(possibleString!) // 需要惊叹号来获取值
3. // 输出 "An optional string."
4.
5. let assumedString: String! = "An implicitly unwrapped optional string."
6. println(assumedString) // 不需要感叹号
7. // 输出 "An implicitly unwrapped optional string."
let possibleString: String? = "An optional string."
let forcedString: String = possibleString! // requires an exclamation mark
let assumedString: String! = "An implicitly unwrapped optional string."
let implicitString: String = assumedString // no need for an exclamation mark”
//摘录来自: Apple Inc. “The Swift Programming Language (Swift 2.2)”。 iBooks.
你可以把隐式解析可选当做一个可以自动解析的可选。你要做的只是声明的时候把感叹号
放到类型的结尾,而不是每次取值的可选名字的结尾。
注意:如果你在隐式解析可选没有值的时候尝试取值,会触发运行时错误。和你在没有值
的普通可选后面加一个惊叹号一样。
你仍然可以把隐式解析可选当做普通可选来判断它是否包含值:
你也可以在可选绑定中使用隐式解析可选来检查并解析它的值:
你仍然可以把隐式解析可选当做普通可选来判断它是否包含值:
1. if assumedString {
2. println(assumedString)
3. }
你也可以在可选绑定中使用隐式解析可选来检查并解析它的值:
4. // 输出 "An implicitly unwrapped optional string."
1. if let definiteString = assumedString { 2. println(definiteString)
3. }
4. // 输出 "An implicitly unwrapped optional string."
注意:如果一个变量之后可能变成 nil 的话请不要使用隐式解析可选。如果你需要在变量的 生命周期中判断是否是 nil 的话,请使用普通可选类型。
错误处理
我们将使用‘error handling’ 来处理在程序执行期间的错误情况 与‘optionals’不同 你可以通过存在或者缺失值来传递一个函数的成功或者失败 ‘error handling’允许你获取强调失败的原因 同时 如果需要 可以把错误变成你程序的一部分
当函数包含一个错误条件处理 它就可以抛出一个错误 那种函数的调用能够捕获错误并且合适的响应错误
func canThorwAnError() throws {
}
函数表明它可以通过在其中声明的‘throws’关键词抛出一个异常 当你调用一个能够抛出异常的函数的时候 你会预先执行try
关键词中的表达 swift自动含有一个传播误差超出他们当前的作用域直到他们被catch
处理
do {
try canThrowAnError()
// 没有错误抛出
} catch {
//有错误抛出
}
do
表达式创建了一个允许错误被一个或者多个catch
包含的新的作用域
下面有一个例子展现了error handling如何对不同的异常的处理
func makeASandwich() throws{
// 。。。
}
do {
try makeASandwich()
eatASandwich()
} catch Error.OutOfCleanDishes {
washDishes()
} catch Error.MissingIngredients(let ingrediends){
buyGroceries()
}
断言
可选可以让你判断值是否存在,你可以在代码中优雅地处理值缺失的情况。然而,在些
情况下,如果值缺失或者值并不满足特定的条件,你的代码可能并不需要继续执行。这 时,你可以在你的代码中触发一个断言(assertion)来结束代码运行并通过调试来找到值 缺失的原因。
使用断言调试
断言会在运行时判断一个逻辑条件是否为 true。从字面意思来说,断言“断言”一个条件是
否为真。你可以使用断言来保证在运行其他代码之前,些重要的条件已经被满足。如果 条件判断为 true,代码运行会继续进行;如果条件判断为 false,代码运行停止,你的应用 被终止。
如果你的代码在调试环境下触发了一个断言,比如你在 Xcode 中构建并运行一个应用, 你可以清楚地看到不合法的状态发生在哪里并检查断言被触发时你的应用的状态。此外, 断言允许你附加一条调试信息。
你可以使用全局 assert 函数来写一个断言。向 assert 函数传入一个结果为 true 或者 false 的表达式以及一条信息,当表达式为 false 的时候这条信息会被显示:
let age = -3
assert(age >= 0 ,"----------")// 因为 age < 0,所以断言会触发
在这个例子中,只有 age >= 0 为 true 的时候代码运行才会继续,也就是说,当 age 的值 非负的时候。如果 age 的值是负数,就像代码中那样,age >= 0 为 false,断言被触发, 结束应用。
断言信息不能使用字符串插值。断言信息可以省略,就像这样:
assert(age >= 0)
何时使用断言
当条件可能为假时使用断言,但是最终一定要保证条件为真,这样你的代码才能继续运
行。断言的适用情景:
- 整数的附属脚本索引被传入一个自定义附属脚本实现,但是下标索引值可能太小或者太 大。
- 需要给函数传入一个值,但是非法的值可能导致函数不能正常执行。 - 一个可选值现在是 nil,但是后面的代码运行需要一个非 nil 值。
网友评论