15

When I set NSZombieEnabled = Yes nothing is written to the console. How can I fix this? Or can you advise me any other tools for an EXC_BAD_ACCESS?

fbrereto
  • 35,429
  • 19
  • 126
  • 178
onur taskin
  • 929
  • 1
  • 14
  • 33

8 Answers8

30

You have a plain old crash. EXC_BAD_ACCESS means that your application has tried to access a memory address that is invalid. While the most typical reason for this in a non-GC'd objective-c application is messaging an object after deallocation, something that Zombie Mode detects, this particular crash can happen any number of other ways (as demonstrated).

Since your application is crashing, you should have a backtrace. You need to post that backtrace here for any of us to be able to help you further.

As Brad said, run your application with debugging enabled. In Xcode, you'll find the "Run/Debug" menu item under the "Run" menu. Use that one. When your application crashes, you should see a stack trace in the upper left corner of the debugger window.

No, really, they do show up in the debugger. A picture is worth 1,000 words. alt text
(source: friday.com)

Glorfindel
  • 21,988
  • 13
  • 81
  • 109
bbum
  • 162,346
  • 23
  • 271
  • 359
  • 7
    This gets my vote for 'Most Unhelpful Answer to a Newbie'. Every newbie like myself knows that plain old EXC_BAD_ACCESS errors do *not* show up in the debugger window, in any case not in a way that is understandable by or helpful to mortals. If they did, the volume of posts on CocoaDev or StackOverflow would easily be half of what they are. (Okay, I exaggerate, three-quarters). – Elise van Looij Feb 03 '10 at 09:12
  • 10
    EXC_BAD_ACCESS is a crash, plain and simple. The debugger catches said crash and displays exactly where it happened. Why it happened in the first place may not be as clear as in that picture. – bbum Feb 03 '10 at 17:32
  • 2
    love the filename (but this is a helpful screenshot +1) – Rob Fonseca-Ensor Feb 03 '10 at 17:33
  • @Rob I create an average of 2 to 5 throwaway projects a day in /tmp/, thus the source of the name. :) – bbum Feb 03 '10 at 17:51
  • Excellent answer. Also, by the end of the day, I have at least three throwaway projects, named DeleteMe1-3 to remind me to clear them out later... – rcw3 Feb 03 '10 at 20:14
  • That's why I make 'em in /tmp/ -- they are eventually pruned automatically. – bbum Feb 03 '10 at 20:17
  • @bbum so is fdfkdjkdfjjdfk sequential? – Rob Fonseca-Ensor Feb 04 '10 at 07:17
10

"EXC_BAD_ACCESS" is not necessarily related to a zombie instance. It can be linked an access to an undefined reference, like a local variable.

NSArray *array;
[array objectAtIndex:0]; // <- Will throw an error

Edit: NSZombie flag will only help you to solve the "EXC_BAD_ACCESS" triggered by the use of a de-allocated instance.

In order to solve the bugs, you have to use the crash backtrace to pinpoint the location that is wrong. Then, go backward into your code and check every assignment and allocations.

Laurent Etiemble
  • 27,111
  • 5
  • 56
  • 81
6

Also make sure you initialize all pointers to nil before using them!

If you use a pointer without initializing it to nil or any other object, you are propably going to end up accessing memory which isn't yours.

For example the following code will also give an EXC_BAD_ACCESS which is not traceable using the NSZombieEnabled flag caused by the last line.

RecordingLocation* closest;

//find the closest recording location
for (...)
{
    //try to find the closest object...
    //suppose we don't find anything so closest is never set.
}

if (closest!=nil)
    NSLog(@"Closest: %f,%f",closest.x,closest.y);
xastor
  • 482
  • 5
  • 17
6

i don't understand how the answer to this question really answers the question..

i am asking myself the same thing. using xcode4 i have enabled NSZobmieEnabled = YES to halt when i access an object that has been released, instead of crashing with EXC_BAD_ACCESS - which is very helpful.

the question at hand was:

"When I set NSZombieEnabled = Yes nothing is written to the console. How can I fix this...".

simple and straight forward.

i am experiencing the same issue. xcode halts with the debugger but the console does not produce any message. i would expect something along the lines of:

"message sent to deallocated instance...".

Nir Pengas
  • 990
  • 9
  • 16
4

Is you search Stack Overflow for EXC_BAD_ACCESS, you'll find a number of people with the same problem that you have. The vast majority of the time that you hit this, you are encountering memory issues. If you are following the protocol described here or here, and you're not seeing any reports of messages being sent to released objects on the console, it might be something different.

Have you tried starting the application in the debugger (Run | Debug - Breakpoints On)? As soon as you hit the EXC_BAD_ACCESS, the debugger should halt. If you look at the backtrace displayed in the debugger (Run | Debugger), it might show you where the error occurred.

Community
  • 1
  • 1
Brad Larson
  • 170,088
  • 45
  • 397
  • 571
1

I had a different experience with EXC_BAD_ACCESS, so I would like to share.

As stated in the questions, even though NSZombieEnabled was checked, nothing was written to the console. After several hours of struggling in the simulator, I decided to install it to the device. The error message that I got from debugging with the device was more helpful.

Eventually, I noticed that I was getting EXC_BAD_ACCESS error and strange behavior because I renamed a couple of xib files a day before. I selected the 'View Controller' object for MainWindow.xib file and corrected the NIB Name property. Then, everything worked smoothly.

Topsakal
  • 447
  • 5
  • 11
1

As I just spent a happy 20 minutes staring at this with NSZombieEnabled not working, I thought I'd add this will cause a EXC_BAD_ACCESS

NSArray *arr = [NSArray arrayWithObjects:@"@dog","@cat",nil];

Note the missing '@' on the second param. I didn't :-)

Dan Bennett
  • 1,450
  • 1
  • 15
  • 17
0

I think Not every EXC_BAD_ACCESS is found by NSZombie Enabling..
Because Some cases I am also not getting result while using zombie..
I think only EXC_BAD_ACCESS related to the use of released object can view by enabling zombie.

And one more issue I noted while using zombie is : Sometimes It also cause crashes on debug. One case I caught crashed, showing :
*** -[MagazineWebview respondsToSelector:]: message sent to deallocated instance 0x58ce2a0
It happens only on when enabling NSZombie.

What I am doing is, On
- (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType
I release the current "MagazineWebview" object and load the given [request URL] in another "MagazineWebview" object. For Achiving my some functionalities...

thanks

Naveen Shan
  • 9,192
  • 3
  • 29
  • 43