EXC_BAD_ACCESS 解决办法

1,今天把工程转换成了ARC,转换完之后,运行程序直接就crash掉了。未转换的时候使用完全没有问题的。

crash的地方是:在登陆的界面,调用发送登陆指令的时候死掉

    [[NSNotificationCenterdefaultCenter]postNotificationName:@"loginCommand"object:packet];一直死在这里,

刚开始怀疑是不是因为arc不支持这种通知机制了,然后测试的时候,把响应这个通知的函数注释掉了,结果就没有crash了,说明问题不在这里。

查看控制台的错误信息:

[__NSCFMutableAr__ loginCommand:] unrecognized selector sent to instance 0x72d24d0'

出现这种错误的原因:

1,实例对象并没有loginCommand:函数 ,这个很容易检查出来

2,实例对象已经释放了,但是对实例对象发送了loginCommand:消息,问题就是出现在了这里。

在网上查了一下EXC_BAD_ACCESS,程序崩溃,网上这么解释的:

向已经释放的对象发送消息时会出现EXC_BAD_ACCESS。当出现错误时,通常会调用堆栈信息,特别是在多线程的情况下,其实就是使用了野指针。

网上的解释:

首先说一下 EXC_BAD_ACCESS 这个错误,可以这么说,90%的错误来源在于对一个已经释放的对象进行release操作。

其实就是使用已经释放的对象,就会出现EXC_BAD_ACCESS。


调试花费了很多时间,走了很多弯路:开始以为是某些文件不能使用arc,因为工程里面很几个第三方的库,兼容了c,都是非arc的。

所以把一些文件又标记成非arc的手动管理内容,结果总是报一些莫名其妙的错误,更加不好定位错误了。


最终查询了EXC_BAD_ACCESS的原因,锁定了错误真正的原因是:持有方法logginCommand的对象已经被释放了,然后调用了这个方法。

结果真的如此:

在XAppDelegate.m文件中

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions

{

    [[XRefreshDataalloc]init];

...

}

看到这句代码基本就知道怎么回事了,这样建立的对象,在使用了arc之后,系统就会自动释放了。

以前之所以未出现问题,是因为没有使用arc,所以这样创建的对象一直存在,而且自己也没有手动的去释放,所以才没出问题。以前的代码漏洞百出啊。汗!


正确的使用方法:

XAppDelegate.h文件中添加XRefreshData *refreshData属性

在XAppDelegate.m文件中把上面这句话改为:

    self.refresh = [[XRefreshDataalloc]init];

这样的话,只要self对象没有释放,那么XrefreshData对象就没有释放,调用loginCommand:方法就不会有问题了。



注意一点:在转换成arc的时候,如果当前大部分文件是arc了,但是想把一个单独的文件转换成arc,在向导界面千万不能只选这这个单独的问题,其他文件也必须勾选,不然其他文件就变成非arc了。


iOS中的exc_bad_access通常是由于访问了无效的内存地址而触发的错误。要解决这个问题,我们可以遵循以下几个步骤: 1. 检查Crash日志:首先,我们应该查看Crash日志以了解问题的具体原因。Crash日志将显示出错的位置以及相关的堆栈信息,这有助于我们确定问题的根源。 2. 使用断点:如果我们知道大概出错的位置,可以在代码中设置断点来逐步调试。这样,我们可以在错误出现前暂停应用程序的执行,从而更好地分析错误。 3. 检查空指针:空指针访问是常见的exc_bad_access错误。我们应该检查代码中的指针变量是否为空并确保在使用前进行了正确的初始化。 4. 检查内存释放:内存管理是另一个常见的exc_bad_access错误的原因。我们需要确保在释放内存之后不再访问已释放的内存。可以使用工具如Instruments来检测内存泄漏和野指针。 5. 使用ARC(自动引用计数):如果我们的应用程序使用了手动管理内存,那么我们应该考虑迁移到ARC来减少内存管理错误的发生。ARC会自动处理内存释放,从而降低了内存相关的问题。 6. 避免循环引用:循环引用也可能导致exc_bad_access错误。我们应该小心使用强引用和弱引用,以避免循环引用的产生。 7. 更新代码库和依赖项:如果我们使用的是第三方库或依赖项,那么我们应该确保它们是最新的版本并且与我们应用程序的其他部分兼容。有时,exc_bad_access错误可能是由于库或依赖项的错误导致的。 总之,解决exc_bad_access错误需要仔细检查代码和内存管理,并根据具体情况进行调试和修复。通过遵循上述步骤,我们可以更好地理解问题并找到适当的解决方案。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值