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
?
问题:
回答1:
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 http://www.friday.com/bbum/wp-content/uploads/2010/02/Crash.png
回答2:
"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.
回答3:
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);
回答4:
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...".
回答5:
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.
回答6:
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 :-)
回答7:
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.
回答8:
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