我有一行代码导致“EXC_BAD_ACCESS”错误。该行代码如下(格式化为一行,为便于阅读去掉了嵌套代码)。
if (![sendData isEqualToString:@"-"]){ ... }
实际错误发生在 IF 线上。奇怪的是,如果我在该行上放置一个断点,则 NSString 称为 sendData(显示为 NSCFString,其值为“-”,不带引号)。为什么这会导致错误?
我有一行代码导致“EXC_BAD_ACCESS”错误。该行代码如下(格式化为一行,为便于阅读去掉了嵌套代码)。
if (![sendData isEqualToString:@"-"]){ ... }
实际错误发生在 IF 线上。奇怪的是,如果我在该行上放置一个断点,则 NSString 称为 sendData(显示为 NSCFString,其值为“-”,不带引号)。为什么这会导致错误?
要解决这个问题,您必须在所有回调方法中设置断点。
问题很简单,代码试图访问它找不到的内存。
找到那行代码更难,因为回调不是按顺序调用的。
从控制台输出:
Attaching to program: `/Users/rjstelling/Library/Application Support/iPhone Simulator/User/Applications/C04A40BB-1D98-402E-BBEF-37E6FB860089/TwoViewApp.app/TwoViewApp', process 24032.
Re-enabling shared library breakpoint 1
2009-04-16 16:16:45.830 TwoViewApp[24032:20b] stream event 1
2009-04-16 16:16:45.831 TwoViewApp[24032:20b] on input stream
2009-04-16 16:16:45.831 TwoViewApp[24032:20b] stream event 1
2009-04-16 16:16:45.832 TwoViewApp[24032:20b] on output stream
2009-04-16 16:16:45.832 TwoViewApp[24032:20b] stream event 4
2009-04-16 16:16:45.832 TwoViewApp[24032:20b] on output stream
2009-04-16 16:16:45.833 TwoViewApp[24032:20b] stream has space open
(gdb) continue
2009-04-16 16:17:06.405 TwoViewApp[24032:20b] We made it - ok!
2009-04-16 16:17:06.406 TwoViewApp[24032:20b] stream event 2
2009-04-16 16:17:06.406 TwoViewApp[24032:20b] on input stream
2009-04-16 16:17:06.407 TwoViewApp[24032:20b] Processing: +OK CONN PinkNotes® Plus Master v5.00.26 Beta (v4 compatible)
:tPNPStr
2009-04-16 16:17:06.407 TwoViewApp[24032:20b] SendData= USER (null):tPNPStr
Current language: auto; currently objective-c
Program received signal: “EXC_BAD_ACCESS”.
(gdb)
问题发生在某个地方或之后ProcessData
,我认为这是一个回调。尝试在 TwoViewAppAppDelegate.m 的第 157 行附近放置一个断点
EXC_BAD_ACCESS
如果您添加,则不是该行导致:
else
{
NSLog(@"We made it - ok!");
}
对于 if() 语句,您可以看到它通过if ( ![sendData isEqualToString:@"-"] ){...}
当您从方法调用返回时会发生错误。
好的,您的评论可能会有所帮助:
如果您使用@"My string"
编译器创建字符串,如果它们具有相同的内容,它们会将它们映射到相同的内存,即:
NSString *var1 = @"string1";
NSString *anotherstring = @"string1";
NSString *morestringivars = @"string1";
都将指向相同的内存空间。
这可能会有所帮助,但我不确定如何?也许您可以发布更多代码,以便我可以在我的设置上运行它。
请记住,在 iPhone 上的事件周期开始时会创建一个自动释放池。
因此,最好在将 sendData 分配给 ivar 后立即在 sendData 上调用 autorelease。
...
[sendData autorelease];
...
听起来您正试图向内存已被释放的对象发送消息。确保您遵循Cocoa 内存管理编程指南中讨论的正确内存管理技术。解决方法可能是[sendData retain]
在释放之前的某个时间点添加 a,但要了解它的工作原理,您必须阅读上述指南。
在发布后将您的对象设置为 nil 以防止在向不可用对象发送消息时崩溃。