博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
xcode4 设置调试错误信息小结
阅读量:5298 次
发布时间:2019-06-14

本文共 1957 字,大约阅读时间需要 6 分钟。

本文中示例的xcode版本为4.3.1

方案1:NSZombieEnabled

先选中工程, 依次 "Product"-"Edit Scheme", 左栏选择"Run...", 右栏选中Arguments,然后在Environment Variables下面添加以下三个属性, 设值为YES

NSDebugEnabled

NSZombieEnabled

NSAutoreleaseFreedObjectCheckEnabled

 有时候在程序出错的时候能准确定位到奔溃的那一行,或者会给你下面这样的提示,而不仅仅是EXEC_BAD_ACCESS:

 

message sent to deallocated instance 0x126550

 

如果要查看上面地址的分配情况

开启MallocStackLogging(Xcode4勾选下MallocStackLogging就行)

出错时shell malloc_history pid address

另:有时候可以重载respondsToSelector可以帮你找到程序崩溃时最后执行的函数,然后排查.

方案2:添加全局断点

Xcode4可以很方便的添加全局的异常断点

 

方案3:中断和未捕获异常

1.未拦截信号来源:内核,其他程序,本身.

常见的两个信号:

1).EXC_BAD_ACCESS试图访问非法内存,导致SIGBUS或者SIGSEGV信号 

2).未能拦截obj_exception_throw导致的SIGABRT信号.

2.方法

1).使用NSUncaughtionHandler安装一个handler拦截未拦截异常

2).使用signal函数安装一个handler拦截BSD信号.(SIGKILL[kill-9]和SIGSTOP[Control+z]无法拦截)

两个c函数

 

void SignalHandler(int signal)  {      //中断信号  }  void uncaughtExceptionHandler(NSException *exception)  {      //未捕获异常  }

安装(与全局异常断点冲突,当有这样的断点是,下面拦截函数失效)

void InstallUncaughtExceptionHandler()  {      NSSetUncaughtExceptionHandler(&uncaughtExceptionHandler);      signal(SIGABRT, SignalHandler);      signal(SIGILL, SignalHandler);      signal(SIGSEGV, SignalHandler);      signal(SIGFPE, SignalHandler);      signal(SIGBUS, SignalHandler);      signal(SIGPIPE, SignalHandler);  }

1.

重点在于尝试继续运行程序

告诉用户那些因为这些未拦截的异常和信号导致的崩溃,或者自己记录,甚至可以避开这样导致的崩溃.不过,如果多个信号拦截了,这可能失效.

非常推荐看看这篇文章

2.

重点在于记录异常(之后返回主线程)

- (void)pumpRunLoop  {      self.finishPump = NO;      CFRunLoopRef runLoop = CFRunLoopGetCurrent();      CFArrayRef runLoopModesRef =     CFRunLoopCopyAllModes(runLoop);      NSArray * runLoopModes = (NSArray*)runLoopModesRef;      while (self.finishPump == NO)      {          for (NSString *mode in runLoopModes)          {              CFStringRef modeRef = (CFStringRef)mode;              CFRunLoopRunInMode(modeRef, 1.0f/120.0f, false);  // Pump the loop at 120 FPS          }      }      CFRelease(runLoopModesRef);  }

转载于:https://www.cnblogs.com/ChenYilong/archive/2012/11/13/2808613.html

你可能感兴趣的文章
MyBaits学习
查看>>
管道,数据共享,进程池
查看>>
CSS
查看>>
[LeetCode] 55. Jump Game_ Medium tag: Dynamic Programming
查看>>
[Cypress] Stub a Post Request for Successful Form Submission with Cypress
查看>>
程序集的混淆及签名
查看>>
thinkphp框架 中 ajax 的应用
查看>>
JAVA排序(一) Comparable接口
查看>>
判断9X9数组是否是数独的java代码
查看>>
00-自测1. 打印沙漏
查看>>
UNITY在VS中调试
查看>>
P1182 数列分段`Section II` P1316 丢瓶盖 二分答案
查看>>
SDUTOJ3754_黑白棋(纯模拟)
查看>>
Scala入门(1)Linux下Scala(2.12.1)安装
查看>>
laravel
查看>>
如何改善下面的代码 领导说了很耗资源
查看>>
Quartus II 中常见Warning 原因及解决方法
查看>>
高德地图 – 1.问题集锦
查看>>
php中的isset和empty的用法区别
查看>>
Android ViewPager 动画效果
查看>>