首页 > 数据库 > mysql教程 > message sent to deallocated instance问题的解决方法(gdb和lldb

message sent to deallocated instance问题的解决方法(gdb和lldb

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
发布: 2016-06-07 15:30:28
原创
1490 人浏览过

http://www.zhaojianfei.com/archives/539 当出现message sent to deallocated instance的时候,一般伴随牛的BAD_ACCESS.是的,是某个对象release了两次。可是那么多的疑对象,到底是哪一个? 使用xcode环境变量(添加 方法 请自行google)MallocStackLoggingNo

http://www.zhaojianfei.com/archives/539


当出现message sent to deallocated instance的时候,一般伴随牛逼的BAD_ACCESS.是的,是某个对象release了两次。可是那么多的疑似对象,到底是哪一个?

使用xcode环境变量(添加方法请自行google)MallocStackLoggingNoCompact,NSZombieEnabled,MallocStackLogging这三个,值都设置成YES.寻求更详细的错误信息。

message sent to deallocated instance后会有一个内存地址,如:0×6497860,我们需要查看该地址的malloc history.查看方法,在原来的gdb下,使用”info malloc_history 0×6497860“即可显示malloc记录。但是新版的Xcode 不再支持,怎么办呢?秀逗麻袋,我们还有terminal,使用终端的malloc_history命令,如”malloc_history 32009 0×6497860“即可显示。其中的32009是该进程的pid,根据这个malloc记录,可以大致定位出错信息的代码位置。

(插一句,gdb或者lldb进行debug的向导:http://lldb.llvm.org/lldb-gdb.html)

其实,如果代码编写足够高效和有序的话,是不会出现这种烦人的问题的。还是代码重构问题。代码洁癖伤不起啊。



相关标签:
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板