Objective-C / iPhone - NSException尽可能多的信息捕获
-
14-11-2019 - |
题
我正在使用以下代码来捕获我的应用程序中的异常:
void uncaughtExceptionHandler(NSException *exception) {
[FlurryAPI logError:@"Uncaught" message:@"Crash!" exception:exception];
}
.
只是想知道我是否可以引脚点,行号,生成的,等等的发生误差。理想情况下,我喜欢尽可能多地详细信息,因为它是由UIView
Analytics捕获的。
flurryapi: http://www.flurry.com/
解决方案
I ended up going with this:
void uncaughtExceptionHandler(NSException *exception) {
NSArray *backtrace = [exception callStackSymbols];
NSString *platform = [[UIDevice currentDevice] platform];
NSString *version = [[UIDevice currentDevice] systemVersion];
NSString *message = [NSString stringWithFormat:@"Device: %@. OS: %@. Backtrace:\n%@",
platform,
version,
backtrace];
[FlurryAPI logError:@"Uncaught" message:message exception:exception];
}
UPDATE (based on @TommyG's comment below):
Add NSSetUncaughtExceptionHandler(&uncaughtExceptionHandler);
to the end of your - -(BOOL)application:didFinishLaunchingWithOptions:
method in AppDelegate
. Then add the above method to the AppDelegate
as well.
其他提示
You can make advantage of the precompiler and write a macro which gathers all the values, eg:
#define __ThrowException(name, reason, class, function, file, line, info) [NSException exceptionWithName:name reason:[NSString stringWithFormat:@"%s:%i (%@:%s) %@", file, line, class, function, reason] userInfo:info];
#define ThrowException(name, reason, info) __ThrowException(name, reason, [self class], _cmd, __FILE__, __LINE__, info)
However, this only works when you throw an exception and from inside an ObjC function (self and _cmd
are the very first parameters you get in an ObjC function, where self is an id which points to the class and _cmd
to the selector which can be (currently!) typecasted to const char).
However, if you want this only for Foundation exceptions, you have two options:
- Wrap everything that might throw an exception in @try() @catch() blocks and then throw a new, custom, exception
- Get the stack trace, this is what might be a little more hard as your app is possible in an inconsistent state and can't gather all the values. Gathering the current stack trace is covered here in great detail.