1.Swift中错误的表示:

“在Swift中如果我们要定义一个表示错误的类型非常简单,只需遵循 Error 协议即可。我们通常用枚举或结构体类型来表示错误类型,当然枚举可能用得更多些,因为它能更直观地表达当前错误类型的每种错误细节。”

摘录来自: “大话Swift 4.0”。 iBooks.

/// 定义一个枚举类型的错误类型
enum MyEnumError: Error {
case errorOne
case errorTwo
 
/// 实现Error协议的localizedDescription只读实例属性
var localizedDescription: String {
let desc = self == .errorOne ? "the first errror" : "the second error"
return "\(self): \(desc)"
}
}
 
/// 定义一个结构体类型的错误类型
struct MyStructError: Error {
var errCode: Int =
 
/// 实现Error协议的localizedDescription只读实例属性
var localizedDescription: String {
return "The error code is: \(errCode)"
}
}
 
print("The enum error is: \(MyEnumError.errorOne.localizedDescription)")
 
print("The struct error is: \(MyStructError().localizedDescription)")

2.Swift中的错误抛出:

“在一个函数或方法中可能要抛出一个错误,
那么我们必须在该函数的形参列表后面,
返回类型前面(即 -> 之前)添加 throws 关键字,以显式告诉编译器,
当前函数可能会抛出错误。” 摘录来自: “大话Swift 4.0”。 iBooks.
/// 因此这里用throws限定。
/// 注意throws的位置
func foo(a: Int) throws -> Int {
if a < - {
// 如果a的值小于-10,
// 则抛出MyEnumError.errorOne
throw MyEnumError.errorOne
}
else if a > {
// 如果a的值大于10,
// 则抛出MyEnumError.errorTwo
throw MyEnumError.errorTwo
}
else if a == {
// 如果a的值为0,
// 那么抛出MyStructError对象,
// 并且其errCode的值为-1
throw MyStructError(errCode: -)
}
 
print("a = \(a)")
 
return a
}
 

3.错误捕获与处理:

“在Swift编程语言中我们使用 do-catch 块对错误进行捕获。”

摘录来自: “大话Swift 4.0”。 iBooks.

// 由于在以下语句中包含了对可抛出错误的函数调用,
// 因此这里使用do语句块将这些调用围起来
do {
// 对于任一可能会抛出错误的函数,
// 在调用前面都必须添加try关键字
var value = try foo(a: -)
value += try foo(a: )
value += try foo(a: )
 
print("value = \(value)")
} // 下面紧接着使用catch语句块
catch let err {
// 如果在do语句块中有任一错误抛出,
// 那么即会执行此catch语句块中的内容
print("err is: \(err)")
}
 
// 无论上面do语句块是否有错误,
// 这句打印均会执行
print("complete")

4.rethrows修饰的函数和方法:

5.将错误转换为可选值:

6.指定清理行为:

defer语句块

func test() {
 
// 编写第一个defer语句块
defer {
print("First defer!")
}
 
print("First stage!")
 
// 编写第二个defer语句块
defer {
print("Second defer!")
}
 
print("Second stage!")
 
// 编写最后一个defer语句块
defer {
print("Last defer!")
}
 
print("Last stage!")
}
 
// 这里函数调用执行之后输出:
// First stage!
// Second stage!
// Last stage!
// Last defer!
// Second defer!
// First defer!
test()

7.Never修饰的函数:

“当一个函数在执行后不会返回时,我们用 Never 作为该函数的返回类型,表示该函数不能返回。”

摘录来自: “大话Swift 4.0”。 iBooks.

“如果我们程序因为某些状态而导致只能做崩溃或退出处理,那么我们可以调用一个不能返回的函数来抛出错误或直接退出。还有就是当前函数执行一个不断接收消息并分发消息的无限循环,该函数将永不退出”。

摘录来自: “大话Swift 4.0”。 iBooks.

Swift4.0复习错误处理的更多相关文章

  1. Swift4.0复习特性、编译标志和检查API的可用性

    1.Swift中的特性: @引出,后面紧跟特性名,圆括号带参数即可. @attribute(args) avaiable: 指明对象,函数,类型的可用性. @available(iOS 10.0, m ...

  2. Swift4.0复习访问控制与作用域

    1.访问等级: open: 可以继承,可以重写. public: “public 访问等级能用于修饰所有文件作用域的函数.对象.协议.枚举.结构体.类以及各种类型中的属性与方法.用 public 所修 ...

  3. Swift4.0复习扩展

    1.扩展计算式属性: 2.对方法进行扩展: /// 定义枚举类型Light, /// 它指定了基本类型String enum Light: String { case red = "red& ...

  4. Swift4.0复习类型定义、类型投射等操作

    1.类型定义: /// 这里将MyInt定义为Int32类型 typealias MyInt = Int32   /// 这里将MyArrayInt定义为[MyInt]数组类型 typealias M ...

  5. Swift4.0复习类

    1.类的属性: 2.类的方法: 3.类作为引用类型: “Swift新增了一对操作符 === 与 !== 用于判定同一个类的两个对象引用是否指向同一对象实例.” 摘录来自: “大话Swift 4.0”. ...

  6. Swift4.0复习协议

    1.协议的定义: /// 定义一个协议MyProt protocol MyProt {   /// 声明了一个实例方法foo, /// 其类型为:() -> Void func foo()   ...

  7. Swift4.0复习结构体

    1.基本语法: /** 定义了一个结构体 */ struct Structure {   /// 一个常量存储式实例属性, /// 并直接为它初始化 let constProperty =   /// ...

  8. Swift4.0复习枚举

    1.枚举类型: “Swift编程语言中,枚举类型属于值类型,而不是引用类型.” 摘录来自: “大话Swift 4.0”. iBooks. 2.枚举类型和枚举对象的定义: enum Enumeratio ...

  9. Swift4.0复习闭包

    1.闭包的定义和调用: _ = { (param1: Int, param2: Float, param3: Void) -> return_type in // 闭包执行代码 /* ... * ...

随机推荐

  1. Backpack V

    Description Given n items with size nums[i] which an integer array and all positive numbers. An inte ...

  2. 使用Fiddler抓包抓取不了数据包的问题

    一:(我)抓包遇到的问题. ①:抓包一直出现这个问题 解决办法:  如果你遇到上面的问题,就可能是证书的问题(我的本地证书是用系统生成证书的一个软件生成的个人证书,所以出现了问题,我抓的所有数据都出现 ...

  3. Oracle row_number() over() 分析函数--取出最新数据

    语法格式:row_number() over(partition by 分组列 order by 排序列 desc) 一个很简单的例子 1,先做好准备 create table test1( id v ...

  4. 【转发】c#做端口转发程序支持正向连接和反向链接

    可以通过中转server来连接sql server,连接的时候用ip,port,不是冒号,是逗号 但试过local port 21想连接AS400的FTP却不成功...为咩涅... https://w ...

  5. Springboot如何优雅的解决ajax+自定义headers的跨域请求[转]

    1.什么是跨域 由于浏览器同源策略(同源策略,它是由Netscape提出的一个著名的安全策略.现在所有支持JavaScript 的浏览器都会使用这个策略.所谓同源是指,域名,协议,端口相同.),凡是发 ...

  6. LibreOJ #6212. 「美团 CodeM 决赛」melon

    二次联通门 : LibreOJ #6212. 「美团 CodeM 决赛」melon /* LibreOJ #6212. 「美团 CodeM 决赛」melon MDZZ 这是决赛题?? */ #incl ...

  7. 【概率论】6-3:中心极限定理(The Central Limit Theorem)

    title: [概率论]6-3:中心极限定理(The Central Limit Theorem) categories: - Mathematic - Probability keywords: - ...

  8. linux (core dump)调试

    转自 http://www.cnblogs.com/hazir/p/linxu_core_dump.html Linux Core Dump 当程序运行的过程中异常终止或崩溃,操作系统会将程序当时的内 ...

  9. Comet OJ - Contest #11题解

    传送门 \(A\) 咕咕咕 const int N=1e6+5; char s[N],t[N];int n,res; inline bool cmp(const int &x,const in ...

  10. Ubuntu系统下,pip3安装python3的pymysql包 报错的问题

    sudo pip3 --version 查看pip3的版本 sudo pip3 install --upgrade pip 更新pip3 sudo pip3 list  查看安装的包列表 如上图, p ...