Swift 1.x的错误处理模式存在很多弊端,例如:为了在编程时候省事,给error参数传递一个nil,或者方法调用完成后不去判断error是否为nil,不进行错误处理。
1
2
3
4
5
6
|
let contents =NSString(contentsOfFile: filePath,
encoding: NSUTF8StringEncoding, error: nil)
//error参数传递一个nil
或者
var err: NSError?
let contents =NSString(contentsOfFile: filePath,
encoding: NSUTF8StringEncoding, error: &err)
|
不好的编程习惯,由于Objective-C和Swift 1.x没有强制处理机制,因此一旦真的发生错误,程序就会发生崩溃。
同样的从文件中读取字符串示例,如果使用Swift2错误处理模式代码如下:
1
2
3
4
5
6
7
8
|
import
Foundation
do
{
//要做一些操作
let str =
try
NSString(contentsOfFile:filePath,
encoding:NSUTF8StringEncoding)
//要尝试做的事情
}
catch
let err as NSError{
//如果失败则进入catch代码块
err.description
}
|
do-try-catch这种错误模式与Java中异常处理机制非常类似,本意就是尝试(try)做一件事情,如果失败则捕获(catch)处理。
捕获错误
完整的do-try-catch错误处理模式的语法如下:
1
2
3
4
5
6
|
do
{
try
语句
成功处理语句组
}
catch
匹配错误{
错误处理语句组
}
|
在try 语句中可以产生错误,当然也可能不会产生错误,如果有错误发生,catch就会处理错误。catch代码块可以有多个,错误由哪个catch代码块处理是由catch后面的错误匹配与否而定的。错误类型的多少就决定了catch可以有多少。我们先介绍一下错误类型。
错误类型
在Swift中错误类型必须遵从ErrorType协议,其次考虑到错误类型的匹配,它应该被设计成为枚举类型,枚举类型非常适合将一组相关值关联起来。
如果我们编写访问数据库表程序,实现对表数据插入、删除、修改和查询等操作,我们会需要类似如下代码的错误类型:
1
2
3
4
|
enum
DAOError: ErrorType {
case
NoData
case
PrimaryKeyNull
}
|
NoData表示没有数据情况,PrimaryKeyNull表示表的主键(Primary Key)为空情况。
那么我们就可以通过如下代码捕获错误。
1
2
3
4
5
6
7
|
do
{
//try 访问数据表函数或方法
}
catch
DAOError.NoData {
print(
"没有数据。"
)
} catchDAOError.PrimaryKeyNull {
print(
"主键为空。"
)
}
|
本文转自 tony关东升 51CTO博客,原文链接:http://blog.51cto.com/tonyguan/1748300,如需转载请自行联系原作者