相信大多数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、

使用MallocStackLogging定位iOS内存错误
本文介绍了一种利用MallocStackLogging来辅助定位iOS应用内存泄漏或释放错误的方法。通过在Executable中设置参数,可以在程序崩溃时获取到更详细的堆栈信息,从而帮助开发者快速定位问题所在的具体代码位置。

被折叠的 条评论
为什么被折叠?



