iPhone开发 捕获提交异常日志

来源:网络 责任编辑:栏目编辑 发表时间:2013-07-02 05:37 点击:

近几个月在公司安排和我个人的要求下,接触了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);
}
这样,如果测试人员或者用户发现崩溃性的问题,我们就很容易找到原因,并进行修正。
如果大家觉得这种策略有什么不足,可以留言讨论。

 

摘自  ahutzh
 

    相关新闻>>

      发表评论
      请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
      用户名: 验证码:点击我更换图片
      最新评论 更多>>

      推荐热点

      • Lexical or Preprocessor Issue 'xxx.h
      • ios学习笔记(二)xcode 4.3.2下实现基本交互
      • ios版本的helloworld
      • iphone(object-c) 内存管理(3) 有效的内存管理 前半部分
      • ios学习笔记(一)xcode 4.3.2下创建第一个ios项目
      • IOS类似iphone通讯录TableView的完整demo【附源码】
      • UITableView一些方法
      • [iPhone中级]iPhone团购信息客户端的开发 (二)
      • iphone(object-c)内存管理(1)
      网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
      Copyright © 2008-2015 计算机技术学习交流网. 版权所有

      豫ICP备11007008号-1