加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

如何在Swift中捕获/记录致命错误?

发布时间:2020-12-14 04:55:36 所属栏目:百科 来源:网络整理
导读:例如,致命错误:在展开Optional值时意外发现nil.无论原因如何,都可以捕获这些数据吗?这是stderr还是其他什么? 编辑:我在http://swiftdoc.org/func/fatalError/找到了一个引用函数(我假设它确实是Swift内部调用的函数)“无条件地打印消息并停止执行.”所以
例如,致命错误:在展开Optional值时意外发现nil.无论原因如何,都可以捕获这些数据吗?这是stderr还是其他什么?

编辑:我在http://swiftdoc.org/func/fatalError/找到了一个引用函数(我假设它确实是Swift内部调用的函数)“无条件地打印消息并停止执行.”所以也许没什么可做的,只能通过TestFlight崩溃报告获得远程崩溃报告,或实际上让设备得心应手.

我能够通过main.swift中的NSSetUncaughtExceptionHandler记录所有未捕获的异常,并且我们可以在应用程序的其他部分进行良好的日志记录,只要发生错误(但可能)错误.我希望还记录这些致命错误,以便我们的日志显示远程测试设备上发生崩溃的更完整图片.

解决方法

某些错误将发送给stderr.这是一个简单的例子:

$cat tryit 
#! /usr/bin/env swift

println ("foo")
precondition (false,"bar")
$./tryit 2> /tmp/error 1> /tmp/noterror
Illegal instruction: 4
$cat /tmp/noterror 
$cat /tmp/error
precondition failed: bar: file ./tryit,line 4
0  swift                    0x000000010f7faa18 llvm::sys::PrintStackTrace(__sFILE*) + 40
1  swift                    0x000000010f7faef4 SignalHandler(int) + 452
...

如果删除前置条件,则结果将转到stdout:

$cat tryit 
#! /usr/bin/env swift

println ("foo")
$./tryit 2> /tmp/error 1> /tmp/noterror
$cat /tmp/noterror 
foo
$cat /tmp/error

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读