class MyError: Error {}
然后,我创建这样的类的实例并检查它是否是NSError
let firstError = MyError()firstError is NSError // Output: false
输出是预期的,我还得到一个警告,指示从’MyError’到无关类型’NSError’的Cast始终失败.这对我来说很有意义,但是如果我稍微更改代码并将变量声明为Error,我会得到一个奇怪的结果:
var secondError: ErrorsecondError = MyError()secondError is NSError // Output: true
在这种情况下,我在最后一行收到警告,说’是’测试始终是真的.当模型以相反的方式定义(NSError:Error)时,我不明白为什么Error总是一个NSError.知道这里发生了什么吗?
解决方法 这是允许Swift错误类型与Objective-C交互的有意行为.编译器只会在将Swift错误桥接到Objective-C时执行强制,或者在你的情况下你所拥有的只是可以包含任何东西的错误存在…记住它也可能来自用Objective编写的throws函数-C.如果您需要将NSError直接传递给某个Objective-C方法作为参数(无论出于何种原因),这也可以让您获得强制.
总结以上是内存溢出为你收集整理的swift – 为什么Error总是NSError?全部内容,希望文章能够帮你解决swift – 为什么Error总是NSError?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)