相信大多数iphone开发者都知道在 Executable中设置NSZombieEnable来显示程序崩溃的位置和具体的信息,但是很多时候程序崩溃的时候都是报出一些一些让我们无法知晓的提示
如:
FREED(id):message release sent to freed object=0x1154a90等一些信息,大概知道其意思,但是我们无法定位在什么地方,这样就相当于没有提示信息一样。
无意间这周在网上发现了另一个提示指令可以更清晰的定义到问题的地方----------就是在
your project ---> Executable -->(双击打开)Arguments 然后添加 MallocStackLogging 并且设置 YES ----> 然后就可以在程序崩溃的时候就可以gdb 一些有用的崩溃信息了。
例如之前的
FREED(id):message release sent to freed object=0x1154a90
这个信息
shell malloc_history <id> <address>
现在我们就可以在gdb 中打印 shell malloc_history 947 0x1154a90 这样就可以定位到具体的某个方法了
当然也可以在终端中去运行 就要去掉以上的shell 指令 如 malloc_history <id> <address>
简直明朗如下图的配置和显示
1、
2、
3、
这样我们就可以定位到 [TestViewCtr showNewPersonController]的data释放问题 这样我们就可以修改了
4、