message sent to deallocated instance
2014-01-12 13:54
423 查看
在XCode的以前版本中,如果遇到了
我们可以使用info malloc-history 0x6d564f0来查看调用堆栈来查看崩溃发生的地方,这种方法这里不作阐述,大家自行百度。
在新的XCode里,调试器默认使用LLDB,我就讲一下如何在LLDB状态下定位到由于内存操作不当引起的Crash
首先我有一段会发生崩溃的代码:
学过内存管理的人都应该知道在这里themePath并没有被retain,所以如果写了release,那么必然会发生崩溃情况。首先我们需要对开发的环境变量进行设置
运行代码,出现下面的崩溃现象
下面我们打开“活动监视器”,找到我们对应的PID,我们的Target为HPThemeManager,只要找到HPThemeManager对应的PID就可以(HPThemeManager是在论坛里下载的,本来正在看代码,就直接拿他来作试验了)
现在,我们得到了两个主要的信息:
进程ID:50127
崩溃地址:0x6d564f0
结果显示为:
这样我们用能定位到这行代码
对themePath进行排查,就找到了崩溃的罪魁祸首
原文地址: http://www.devdiv.com/lldb_message_sent_to_deallocated_instance_-blog-50901-50856.html
[代码]c#/cpp/oc代码:
1 | message sent to deallocated instance 0x6d564f0 |
在新的XCode里,调试器默认使用LLDB,我就讲一下如何在LLDB状态下定位到由于内存操作不当引起的Crash
首先我有一段会发生崩溃的代码:
[代码]c#/cpp/oc代码:
1 | NSString *themePath = [[[NSBundle mainBundle] resourcePath] stringByAppendingPathComponent:themePathTmp]; |
2 | if (themePath) |
3 | self.backgroundIV.image = [UIImage imageWithContentsOfFile:[themePath stringByAppendingPathComponent: @"mask_1.png" ]]; |
4 |
5 | [themePath release]; |
运行代码,出现下面的崩溃现象
下面我们打开“活动监视器”,找到我们对应的PID,我们的Target为HPThemeManager,只要找到HPThemeManager对应的PID就可以(HPThemeManager是在论坛里下载的,本来正在看代码,就直接拿他来作试验了)
现在,我们得到了两个主要的信息:
进程ID:50127
崩溃地址:0x6d564f0
我们打开终端,输入以下命令:
[代码]c#/cpp/oc代码:
1 | sudo malloc_history 50127 0x6d564f0 |
这样我们用能定位到这行代码
[代码]c#/cpp/oc代码:
1 | NSString *themePath = [[[NSBundle mainBundle] resourcePath] stringByAppendingPathComponent:themePathTmp]; |
[代码]c#/cpp/oc代码:
1 | [themePath release]; |
相关文章推荐
- 【解决】Internet访问看似正常(无叹号受限)却打不开网页
- LeetCode: Reorder List
- memset 用法
- 加载图片的时候使用classloader与不适用有什么区别吗??求各位指导下小白啊
- java获取当前系统时间
- Software Architecture
- 用 Python ctypes 来调用 C/C++ 编写的第三方库
- A + B Problem (Big integer version) 【高精度】
- 简单的五子棋(人人对战)
- 仿射变换
- 年份的读法与读数字不同
- 唐山校友会会长苏伟与徐飞校长的一次短信交流
- IOS之操作表ActionSheet(免Delegate)
- 数据存储过程
- 四代i5超值配置单,年度最便宜4代
- 元素的position:absolute;属性和margin-left:480px; margin-top:-20px配合使用
- Cython基础--Cython入门
- Fib数列问题2
- 如何发挥协调战斗能力
- 学习笔记五:Ubuntu下载编译Android源码