xcode4 设置调试错误信息小结

xcode4 设置调试错误信息小结

方案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函数

 

[cpp]  viewplain copy
  1. void SignalHandler(int signal)  
  2.  
  3. //中断信号  
  4.  
  5.   
  6.   
  7. void uncaughtExceptionHandler(NSException *exception)  
  8.  
  9. //未捕获异常  
  10.  


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

[cpp]  viewplain copy
  1. void InstallUncaughtExceptionHandler()  
  2.  
  3.     NSSetUncaughtExceptionHandler(&uncaughtExceptionHandler);  
  4.     signal(SIGABRT, SignalHandler);  
  5.     signal(SIGILL, SignalHandler);  
  6.     signal(SIGSEGV, SignalHandler);  
  7.     signal(SIGFPE, SignalHandler);  
  8.     signal(SIGBUS, SignalHandler);  
  9.     signal(SIGPIPE, SignalHandler);  
  10.  

3.具体实例

1.http://cocoawithlove.com/2010/05/handling-unhandled-exceptions-and.html

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

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

非常推荐看看这篇文章

2.http://parveenkaler.com/2010/08/11/crashkit-helping-your-iphone-apps-suck-less/

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

[cpp]  viewplain copy
  1. (void)pumpRunLoop  
  2.  
  3.     self.finishPump NO;  
  4.     CFRunLoopRef runLoop CFRunLoopGetCurrent();  
  5.     CFArrayRef runLoopModesRef     CFRunLoopCopyAllModes(runLoop);  
  6.     NSArray runLoopModes (NSArray*)runLoopModesRef;  
  7.     while (self.finishPump == NO)  
  8.      
  9.         for (NSString *mode in runLoopModes)  
  10.          
  11.             CFStringRef modeRef (CFStringRef)mode;  
  12.             CFRunLoopRunInMode(modeRef, 1.0f/120.0f, false);  // Pump the loop at 120 FPS  
  13.          
  14.      
  15.     CFRelease(runLoopModesRef);  
  16.  

SIGKILL,程序在ios4下启动不了   

我把以前用sdk3写的代码升级到SDK4.0的模拟器上运行,退出时GDB提示Program received signal:  “SIGKILL”.
再次启动程序时程序启动不了.
在真机测试有时能起来有时起不来,如果起不来关机再开机,再启动就能起来
请问1. "SIGKILL"是什么情况下产生的?
       2. 如何解决?

注释:单击home是后台挂起,在双击home后才退出。


有哪位大侠知道敬请指教!不慎感激!



plist 加上UIApplicationExitsOnSuspend bool 值
參考這裡
UIApplicationExitsOnSuspend = Application does not run in background

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值