开发者

NSMutableString appendString generates SIGABRT Error

New here (this forum and Xcode in general), so bear with me.

I've spent multiple hours off and on over the last severals days trying to track down what exactly that I'm doing wrong here, but I just don't seem to be able to pinpoint my issue.

Here's the开发者_高级运维 relevant sections of my code (I believe).

In the header:

@interface BlahViewController : UIViewController {

  NSMutableString *display;

}

@property (nonatomic, retain) NSMutableString *display;

In the main:

@implementation BlahViewController

@synthesize display;

- (void)viewDidLoad {
    self.display = [[NSMutableString alloc] init];  
}

- (void)anotherFunction:(UIButton *)sender {

    NSString *info = [[sender titleLabel] text];

    [self.display appendString:info];
}

I run the code, press the UIButton, and I get an error. Here's the initial throw:

  *** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '-[__NSArrayM appendString:]: unrecognized selector sent to instance 0x4e3d300' ***

Thanks!

EDIT: The whole stack trace was requested, so here it is (after reviewing the stack I realize there may be confusion, I'm writing a very basic calculator currently, so the ViewController, etc, should consider that backdrop and "anotherFunction" = "digitPressed" in this particular case):

* Call stack at first throw: (

0 CoreFoundation 0x00e345a9 exceptionPreprocess + 185

1 libobjc.A.dylib 0x00f88313 objc_exception_throw + 44

2 CoreFoundation 0x00e360bb -[NSObject(NSObject) doesNotRecognizeSelector:] + 187

3 CoreFoundation 0x00da5966 __forwarding + 966

4 CoreFoundation 0x00da5522 _CF_forwarding_prep_0 + 50

5 Calculator 0x0000273b -[CalculatorViewController digitPressed:] + 113

6 UIKit 0x002bb4fd -[UIApplication sendAction:to:from:forEvent:] + 119

7 UIKit 0x0034b799 -[UIControl sendAction:to:forEvent:] + 67

8 UIKit 0x0034dc2b -[UIControl(Internal) _sendActionsForEvents:withEvent:] + 527

9 UIKit 0x0034c7d8 -[UIControl touchesEnded:withEvent:] + 458

10 UIKit 0x002dfded -[UIWindow _sendTouchesForEvent:] + 567

11 UIKit 0x002c0c37 -[UIApplication sendEvent:] + 447

12 UIKit 0x002c5f2e _UIApplicationHandleEvent + 7576

13 GraphicsServices 0x01723992 PurpleEventCallback + 1550

14 CoreFoundation 0x00e15944 CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE1_PERFORM_FUNCTION + 52

15 CoreFoundation 0x00d75cf7 __CFRunLoopDoSource1 + 215

16 CoreFoundation 0x00d72f83 __CFRunLoopRun + 979

17 CoreFoundation 0x00d72840 CFRunLoopRunSpecific + 208

18 CoreFoundation 0x00d72761 CFRunLoopRunInMode + 97

19 GraphicsServices 0x017221c4 GSEventRunModal + 217

20 GraphicsServices 0x01722289 GSEventRun + 115

21 UIKit 0x002c9c93 UIApplicationMain + 1160

22 Calculator 0x00002254 main + 102

23 Calculator 0x000021e5 start + 53

)

terminate called after throwing an instance of 'NSException'

Current language: auto; currently objective-c


* Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '-[__NSArrayM appendString:]: unrecognized selector sent to instance 0x4e3d300' *

This indicates that you are calling appendString: an instance of some kind of NSArray, which obviously won't work.

Assuming that [self.display appendString:info]; is the actual source of the exception, then it is happening because self.display has likely been over-released and, coincidentally, an NSArray instance was allocated at the same place in memory.

You could use zombie detection to debug this.

Alternatively, you might be corrupting memory somewhere. Or, maybe, there is another assignment to display.

In any case, whenever you have a crash, there will be a backtrace. Please post it. There is the off chance that the crash is happening somewhere else.


5 Calculator 0x0000273b -[CalculatorViewController digitPressed:] + 113

Show the source to your digitPressed: method.


self.display = [[NSMutableString alloc] init];  

That is a memory leak; it'll be retained twice. Just do self.display = [NSMutableString string]; and self.display = nil; (in your viewDidUnload).

But that isn't the source of your problem; something is resetting the display variable or it is being over-released. Show all uses of display.

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜