Swift—do-try-catch错误处理模式-备

Swift 1.x的错误处理模式存在很多弊端,例如:为了在编程时候省事,给error参数传递一个nil,或者方法调用完成后不去判断error是否为nil,不进行错误处理。

 

  1. let contents = NSString(contentsOfFile: filePath,
  2. Êencoding: NSUTF8StringEncoding, error: nil)//error参数传递一个nil

或者

 

  1. var err: NSError?
  2. let contents = NSString(contentsOfFile: filePath,
  3. Êencoding: NSUTF8StringEncoding, error: &err)

不好的编程习惯,由于Objective-C和Swift 1.x没有强制处理机制,因此一旦真的发生错误,程序就会发生崩溃。

同样的从文件中读取字符串示例,如果使用Swift2错误处理模式代码如下:

 

  1. import Foundation
  2. do {        //要做一些操作
  3. let str = try NSString(contentsOfFile: filePath,
  4. Êencoding: NSUTF8StringEncoding)    //要尝试做的事情
  5. } catch let err as NSError { //如果失败则进入catch代码块
  6. err.description
  7. }

do-try-catch这种错误模式与Java中异常处理机制非常类似,本意就是尝试(try)做一件事情,如果失败则捕获(catch)处理。

捕获错误

完整的do-try-catch错误处理模式的语法如下:

 

  1. do {
  2. try 语句
  3.   成功处理语句组
  4. } catch 匹配错误 {
  5. 错误处理语句组
  6. }

在try 语句中可以产生错误,当然也可能不会产生错误,如果有错误发生,catch就会处理错误。catch代码块可以有多个,错误由哪个catch代码块处理是由catch后面的错误匹配与否而定的。错误类型的多少就决定了catch可以有多少。我们先介绍一下错误类型。

错误类型

在Swift中错误类型必须遵从ErrorType协议,其次考虑到错误类型的匹配,它应该被设计成为枚举类型,枚举类型非常适合将一组相关值关联起来。

如果我们编写访问数据库表程序,实现对表数据插入、删除、修改和查询等操作,我们会需要类似如下代码的错误类型:

 

  1. enum DAOError: ErrorType {
  2. case NoData
  3. case PrimaryKeyNull
  4. }

NoData表示没有数据情况,PrimaryKeyNull表示表的主键(Primary Key)为空情况。

那么我们就可以通过如下代码捕获错误。

 

    1. do {
    2. //try 访问数据表函数或方法
    3. } catch DAOError.NoData {
    4. print("没有数据。")
    5. } catch DAOError.PrimaryKeyNull {
    6. print("主键为空。")
    7. }
  1. 能放到try后面调用函数或方法都是有要求的,他们是有可能抛出错误,在这些函数或方法声明的参数后面要加上throws关键字,表示这个函数或方法可以抛出错误。

    声明抛出错误方法示例代码如下:

    [html] view plain copy

    print?

    1. //删除Note记录方法
    2. func remove(model: Note) throws {
    3. ...
    4. }
    5. //查询所有记录数据方法
    6. func findAll() throws -> [Note] {
    7. ...
    8. }

    上述代码remove(_:)方法没有返回值,throws关键字放到参数后面。findAll()有返回值throws关键字放到参数和返回值类型之间。

    在函数或方法中抛出错误

    一个函数或方法能够声明抛出错误,是因为在函数或方法中产生并抛出了错误,这样函数或方法声明抛出错误才有实际的意义。

    在产生并抛出错误方式:

    • 在函数或方法中通过throw语句,人为地抛出错误。
    • 在函数或方法中调用的其他可以抛出错误函数或方法,但是没有捕获处理,会导致错误被传播出来。

      示例代码如下:

      [html] view plain copy

      print?

      1. //删除Note方法
      2. func remove(model: Note) throws {
      3. guard let date = model.date else {        //判断抛出时候是有了guard语句
      4. //抛出"主键为空"错误
      5. throw DAOError.PrimaryKeyNull
      6. }
      7. //比较日期主键是否相等
      8. for (index, note) in listData.enumerate() where note.date == date {
      9. listData.removeAtIndex(index)
      10. }
      11. }
      12. //查询所有数据方法
      13. func findAll() throws -> [Note] {
      14. guard listData.count > 0 else {           //判断抛出时候是有了guard语句
      15. //抛出"没有数据"错误。
      16. throw DAOError.NoData
      17. }
      18. return listData
      19. }
      20. func printNotes() throws {               //声明抛出错误
      21. let datas  = try findAll()
      22. for note in datas {
      23. print("date : \(note.date!) - content: \(note.content!)")
      24. }
      25. }
      26. try printNotes()

    guard语句最擅长处理这种早期判断,条件为false情况下抛出错误。

    findAll()语句本身有可能产生错误,但是并没有使用catch语句捕获并处理,这样就导致了这个错误传播给该函数或方法的调用者,如果它的调用者也都不捕获处理,那么最后程序会出现运行期错误。

时间: 2024-10-10 12:57:51

Swift—do-try-catch错误处理模式-备的相关文章

Swift—Cocoa错误处理模式-备

Swift错误处理模式,在Swift1.x和Swift 2.0是不同的两种模式. Swift 1.x代码错误处理模式采用Cocoa框架错误处理模式,到现在Objective-C还沿用这种处理模式,而Swift2.0之后采用了do-try-catch错误处理模式. 下面的示例代码是从文件中读取字符串到内存中,如果使用Swift 1.x错误处理模式代码如下:   import Foundation var err: NSError?        //定义可选的NSError?变量 let cont

《从零开始学Swift》学习笔记(Day 53)——do-try-catch错误处理模式

原创文章,欢迎转载.转载请注明:关东升的博客 Swift 1.x的错误处理模式存在很多弊端,例如:为了在编程时候省事,给error参数传递一个nil,或者方法调用完成后不去判断error是否为nil,不进行错误处理. let contents = NSString(contentsOfFile: filePath, Êencoding: NSUTF8StringEncoding, error: nil)//error参数传递一个nil 或者 var err: NSError? let conte

《从零開始学Swift》学习笔记(Day 52)——Cocoa错误处理模式

原创文章,欢迎转载. 转载请注明:关东升的博客 Swift错误处理模式,在Swift1.x和Swift 2.0是不同的两种模式. Swift 1.x代码错误处理模式採用Cocoa框架错误处理模式,到如今Objective-C还沿用这样的处理模式,而Swift2.0之后採用了do-try-catch错误处理模式. 以下的演示样例代码是从文件里读取字符串到内存中,假设使用Swift 1.x错误处理模式代码例如以下: import Foundation var err: NSError? //定义可选

《从零开始学Swift》学习笔记(Day 52)——Cocoa错误处理模式

原创文章,欢迎转载.转载请注明:关东升的博客 Swift错误处理模式,在Swift 1.x和Swift 2.0是不同的两种模式. Swift 1.x代码错误处理模式采用Cocoa框架错误处理模式,到现在Objective-C还沿用这种处理模式,而Swift 2.0之后采用了do-try-catch错误处理模式. 下面的示例代码是从文件中读取字符串到内存中,如果使用Swift 1.x错误处理模式代码如下: import Foundation var err: NSError? //定义可选的NSE

PDO 中支持三种错误处理模式:

PDO 支持三种错误处理模式: 静默模式,警告模式,异常模式 静默模式是默认的,需要修改的话,通过设置 PDO 对象的属性完成. $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_SILENT)? $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_WARNING)?? $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_SILENT)?

Swift 语言的设计错误有哪些?

其实 Swift 1.0 刚出来的时候,我就发现它的 array 可变性设计存在严重的错误.Swift 2.0 修正了这个问题,然而他们的修正方法却没有击中要害,所以导致了其它的问题.这个错误一直延续到今天. Swift 1.0 试图利用 var 和 let 的区别来指定 array 成员的可变性,然而其实 var 和 let 只能指定 array reference 的可变性,而不能指定 array 成员的可变性.举个例子,Swift 1.0 试图实现这样的语义: var shoppingLi

SQL Server Try Catch错误处理

一.语法要点:BEGIN TRY     { sql_statement | statement_block } END TRY BEGIN CATCH           [ { sql_statement | statement_block } ] END CATCH [ ; ] 异常部分: 在 CATCH 块的作用域内,可以使用以下系统函数来获取导致 CATCH 块执行的错误消息: ERROR_NUMBER() 返回错误号. ERROR_SEVERITY() 返回严重性. ERROR_ST

PDO 提供了三种不同的错误处理模式

PDO::ERRMODE_SILENT 此为默认模式. PDO 将只简单地设置错误码,可使用 PDO::errorCode() 和 PDO::errorInfo() 方法来检查语句和数据库对象.如果错误是由于对语句对象的调用而产生的,那么可以调用那个对象的 PDOStatement::errorCode() 或 PDOStatement::errorInfo() 方法.如果错误是由于调用数据库对象而产生的,那么可以在数据库对象上调用上述两个方法. PDO::ERRMODE_WARNING 除设置

PHP PDO的错误处理模式

PDO默认的错误处理方式是返回一个数组格式的错误代码.如果想要判断SQL有没有出错时,就需要写一组代码来检测这个返回的数组.觉得这样有些麻烦.还好PDO还提供了另外两种处理方式,只要根据需要设置一下就OK了. 方式一:PDO::ERRMODE_SILENT 这是默认使用的模式.PDO会在statement和database对象上设定简单的错误代号,可以使用PDO->errorCode() 和 PDO->errorInfo() 方法检查错误: 方式二:PDO::ERRMODE_WARNING 使