如何在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 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |