我想在某些点记录调用跟踪,比如失败的断言或未捕获的异常。
这基本上告诉你该怎么做。
本质上,你需要设置应用程序异常处理日志,类似于:
#import <ExceptionHandling/NSExceptionHandler.h>
[[NSExceptionHandler defaultExceptionHandler]
setExceptionHandlingMask: NSLogUncaughtExceptionMask |
NSLogUncaughtSystemExceptionMask |
NSLogUncaughtRuntimeErrorMask]
Cocoa已经将未捕获异常的堆栈跟踪记录到控制台,尽管它们只是原始内存地址。如果你想要控制台的符号信息,有一些来自苹果的示例代码。
如果您想在代码中的任意点生成堆栈跟踪(并且您在Leopard上),请参阅反向跟踪手册页。在使用Leopard之前,您实际上必须挖掘调用堆栈本身。
这段代码适用于任何线程:
NSLog(@"%@", NSThread.callStackSymbols);
返回包含调用堆栈符号的数组。每个元素都是一个NSString对象,其值的格式由backtrace_symbols()函数决定。
n13的答案不太管用——我稍微修改了一下,得出了这个答案
#import <UIKit/UIKit.h>
#import "AppDelegate.h"
int main(int argc, char *argv[])
{
@autoreleasepool {
int retval;
@try{
retval = UIApplicationMain(argc, argv, nil, NSStringFromClass([AppDelegate class]));
}
@catch (NSException *exception)
{
NSLog(@"Gosh!!! %@", [exception callStackSymbols]);
@throw;
}
return retval;
}
}
推荐文章
- 在Objective-C中@property保留,赋值,复制,非原子
- 我如何在NSAttributedString中创建一个可点击的链接?
- 停止UIWebView垂直“弹跳”?
- 对未渲染的视图进行快照,结果是一个空快照
- 开始使用instancetype而不是id是否有益?
- 我可以强制UITableView隐藏分隔符之间的空单元格吗?
- 为什么Objective-C文件使用。m扩展名?
- Objective-C for Windows
- 获得推送通知,而应用程序在前台iOS
- 如何取消选定的UITableView单元格?
- 设置自定义UITableViewCells的高度
- 将NSString转换为NSDate(然后再转换回来)
- applicationwillenter前台vs. applicationDidBecomeActive, applicationWillResignActive vs. applicationDidEnterBackground
- iOS 7导航栏文本和箭头颜色
- 如何在iOS上进行base64编码?