在Swift 2.0中NSError符合ErrorType协议。
对于自定义的错误,我们可以为某些情况指定关联对象,如下所示。
enum LifeError: ErrorType { case BeBorn case LostJob(job: String) case GetCaughtByWife(wife: String) ... }
我们可以舒适地做以下事情:
do { try haveAffairWith(otherPerson) } catch LifeError.GetCaughtByWife(let wife) { ... }
然而,如果我们想要它作为NSError传递到其他地方,它会丢失其关联对象信息。
println("\(LifeError.GetCaughtByWife("Name") as NSError)")
打印:
Error Domain=... Code=1 "The operation Couldn't be completed". (... error 1)
并且其userInfo为nil。
我的妻子在哪里与ErrorType关联?
Xcode 8中的新功能:CustomNSError
protocol。
enum LifeError: Error,CustomNSError { case beBorn case lostJob(job: String) case getCaughtByWife(wife: String) static var errorDomain: String { return "LifeError" } var errorCode: Int { switch self { case .beBorn: return 0 case .lostJob(_): return 1 case .getCaughtByWife(_): return 2 } } var errorUserInfo: [String : AnyObject] { switch self { case .beBorn: return [:] case .lostJob(let job): return ["Job": job] case .getCaughtByWife(let wife): return ["Wife": wife] } } }
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。