时间:2021-05-20
iOS开发,最郁闷的莫过于程序毫无征兆地就崩溃了,用bt命令打出调用栈,给出的是一堆系统EXC_BAD_ACCESS的信息,根本没办法定位问题出现在哪里。 首先说一下 EXC_BAD_ACCESS 这个错误,可以这么说,90%的错误来源在于对一个已经释放的对象进行release操作。举一个简单的例子来说明吧,首先看一段Java代码:
复制代码 代码如下:
public class Test{
public static void main(String[] args){
String s = "This is a test string";
s = s.substring(s.indexOf("a"),(s.length()));
System.out.println(s);
}
}
通常这样的崩溃出现,原因一般就是:调用了已经释放的内存空间,或者说重复释放了某个地址空间。而怎样定位到这个地址呢,可以通过编辑xcode的scheme,添加如下标记位,让系统把错误地址打印出来,如图:
(通过Product->Scheme->Edit Scheme进入下面编辑页面,选中Arguments tab,增加标计位NSZombieEnabled设为YES)
这样,但崩溃出现,系统会出现以下提示信息:
2013-06-23 00:45:20.479 *** -[__NSArrayM addObject:]: message sent to deallocated instance 0x7179910
可见崩溃原因是内存地址0x7179910被重复释放了。
Objective-C 这段代码有三个致命问题:1、内存泄露;2、错误释放;3、造成 EXC_BAD_ACCESS 错误。
如果崩溃是发生在当前调用栈,通过上面的做法,系统就会把崩溃原因定位到具体代码中。但是,如果崩溃不在当前调用栈,系统就仅仅只能把崩溃地址告诉我们,而没办法定位到具体代码,这样我们也没法去修改错误。这时就可以修改scheme,让xcode记录每个地址alloc的历史,这样我们就可以用命令把这个地址还原出来。如图:(跟设置NSZombieEnabled一样,添加MallocStackLoggingNoCompact,并且设置为YES)
这样,当出现崩溃原因是message sent to deallocated instance 0x7179910,我们可以使用以下命令,把内存地址还原:
info malloc-history0x7179910
如图,这个命令能具体把这个地址在哪一行代码生成还原出来。
(需要注意的是,因为这个命令只支持gdb,所以必须把控制台的输出改成gdb,并且有点遗憾的是,只支持模拟器,不支持真机调试)
(同样是通过Product->Scheme->Edit Scheme进入上面编辑页面,选中Info tab)
这样,好好检查一下那一行的代码,应该就很容易找出问题所在了。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
今天从ios5.1更新ios5.11时出现3194错误,在网上找了大半天的的解决方式都试过了,下面小编就为大家介绍iOS恢复时发生未知错误3194的解决方法
memtest有错误就是说内存出现错误,数据检验失败。解决方法: 1、首先检查一下内存是否被超频了。有些内存体质不是很好,默认频率下很稳定,但只要一超频就出错
本文提供了Access数据库不能写不能更新的解决方法,主要是权限原因,具体看下面的具体解决方法Access数据库不能写,造成这种问题的原因是Web共享文件夹在N
电脑升级内存条常见故障的原因及解决方法 图2 电脑升级内存条常见故障的原因及解决方法 图3 电脑升级内存条常见故障的原因及解决方法 图4 安装内存条的
ios8升级内存不够怎么办?小编带来了升级ios8正式版内存不够解决方法,900多MB的软件需要5GB的存储空间,这让很多果粉表示很头疼,该如何解决呢?