iPhone开发如何捕获提交异常日志


from http://www.cctime.com/html/2012-3-22/20123221659503123.htm

IT168技术】近几个月在公司安排和我个人的要求下,接触了iPhone方面的开发,主要都是应用方面的,参与了两个iPhone项目的开发,并且已经比较至AppStore了,终于可以休息一段时间了。

项目开发中,经常遇到一个问题。每次辛苦的发布版本给测试人员测试后,收获一推Bug,面对这些问题,有些问题还是很容易就找到的,那些很难重现的问题就让人无语了。如果不是在模拟器上,又或者我们的设备没有连接到PC上,那么如何调试我们的程序呢?如果应用已经发不到AppStore了,用户在使用过程中出现了问题,我们当然希望能够感知到这个问题,并在更新下个版本时修改和完善我们的应用。

这就引出一个需求:捕获应用使用时出现的异常,提交至服务器或者开发者的邮箱。

废话不多说,直接上代码。

1、用于处理未被try...catch...捕获的异常

void UncaughtExceptionHandler(NSException *exception) {

// 异常的堆栈信息

NSArray *stackArray = [exception callStackSymbols];

// 出现异常的原因

NSString *reason = [exception reason];

// 异常名称

NSString *name = [exception name];

NSString *syserror = [NSString stringWithFormat:@"异常名称:%@\n异常原因:%@\n异常堆栈信息:%@",name, reason, stackArray];

NSLog(@"%@", syserror);

// 发送异常至开发者的邮箱或者发送至服务器端

}

2、在应用启动的地方替换系统原有的处理异常的Handler

// 保存系统处理异常的Handler

_uncaughtExceptionHandler = NSGetUncaughtExceptionHandler;

// 设置处理异常的Handler

NSSetUncaughtExceptionHandler(&UncaughtExceptionHandler);

3、在应用退出时,还原异常处理的Handler

- (void)applicationWillTerminate:(UIApplication *)application

{

// 还原为系统处理异常的Handler

NSSetUncaughtExceptionHandler(_uncaughtExceptionHandler);

}


from:http://blog.csdn.net/ahutzh/article/details/7360795

好久没有更新博客了,之前CSDN给我颁发的[持之以恒]奖章都灰掉了快哭了 ,虽然奖章无所谓,不过记录自己学习经历的这种好习惯还是要坚持的。奋斗

近几个月在公司安排和我个人的要求下,接触了iPhone方面的开发,主要都是应用方面的,参与了两个iPhone项目的开发,并且已经比较至AppStore了,终于可以休息一段时间了。大笑

项目开发中,经常遇到一个问题。每次辛苦的发布版本给测试人员测试后,收获一推Bug,面对这些问题,有些问题还是很容易就找到的,那些很难重现的问题就让人无语了。如果不是在模拟器上,又或者我们的设备没有连接到PC上,那么如何调试我们的程序呢?如果应用已经发不到AppStore了,用户在使用过程中出现了问题,我们当然希望能够感知到这个问题,并在更新下个版本时修改和完善我们的应用。

这就引出一个需求:捕获应用使用时出现的异常,提交至服务器或者开发者的邮箱。

废话不多说,直接上代码。

1、用于处理未被try...catch...捕获的异常

[java]  view plain copy
  1. void UncaughtExceptionHandler(NSException *exception) {  
  2.     // 异常的堆栈信息  
  3.     NSArray *stackArray = [exception callStackSymbols];  
  4.     // 出现异常的原因  
  5.     NSString *reason = [exception reason];  
  6.     // 异常名称  
  7.     NSString *name = [exception name];  
  8.       
  9.     NSString *syserror = [NSString stringWithFormat:@"异常名称:%@\n异常原因:%@\n异常堆栈信息:%@",name, reason, stackArray];  
  10.     NSLog(@"%@", syserror);  
  11.       
  12.     // 发送异常至开发者的邮箱或者发送至服务器端  
  13. }  

2、在应用启动的地方替换系统原有的处理异常的Handler

[java]  view plain copy
  1. - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions  
  2. {  
  3.     // 保存系统处理异常的Handler  
  4.     _uncaughtExceptionHandler = NSGetUncaughtExceptionHandler();  
  5.     // 设置处理异常的Handler  
  6.     NSSetUncaughtExceptionHandler(&UncaughtExceptionHandler);  
  7.       
  8.     self.window = [[[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]] autorelease];  
  9.     // Override point for customization after application launch.  
  10.     self.viewController = [[[ViewController alloc] initWithNibName:@"ViewController" bundle:nil] autorelease];  
  11.     self.window.rootViewController = self.viewController;  
  12.     [self.window makeKeyAndVisible];  
  13.     return YES;  
  14. }  
3、在应用退出时,还原异常处理的Handler

[java]  view plain copy
  1. - (void)applicationWillTerminate:(UIApplication *)application  
  2. {  
  3.     // 还原为系统处理异常的Handler  
  4.     NSSetUncaughtExceptionHandler(_uncaughtExceptionHandler);  
  5. }  
这样,如果测试人员或者用户发现崩溃性的问题,我们就很容易找到原因,并进行修正。

如果大家觉得这种策略有什么不足,可以留言讨论。大笑

你可能感兴趣的:(iPhone开发如何捕获提交异常日志)