0

我有一行代码导致“EXC_BAD_ACCESS”错误。该行代码如下(格式化为一行,为便于阅读去掉了嵌套代码)。

if (![sendData isEqualToString:@"-"]){ ... }

实际错误发生在 IF 线上。奇怪的是,如果我在该行上放置一个断点,则 NSString 称为 sendData(显示为 NSCFString,其值为“-”,不带引号)。为什么这会导致错误?

4

3 回答 3

2

要解决这个问题,您必须在所有回调方法中设置断点。

问题很简单,代码试图访问它找不到的内存。

找到那行代码更难,因为回调不是按顺序调用的。

  1. 添加更多断点
  2. 添加更多 NSLog(..)
  3. 考虑捕获异常(参见在objective-c/cocoa 中抛出异常

从控制台输出:

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];

...
于 2009-04-16T14:19:45.687 回答
1

听起来您正试图向内存已被释放的对象发送消息。确保您遵循Cocoa 内存管理编程指南中讨论的正确内存管理技术。解决方法可能是[sendData retain]在释放之前的某个时间点添加 a,但要了解它的工作原理,您必须阅读上述指南。

于 2009-04-16T14:07:52.517 回答
0

在发布后将您的对象设置为 nil 以防止在向不可用对象发送消息时崩溃。

于 2009-04-16T21:27:19.687 回答