NSZombieEnabled does not work

前端 未结 8 1665
谎友^
谎友^ 2020-12-15 07:59

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?

相关标签:
8条回答
  • 2020-12-15 08:00

    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);
    
    0 讨论(0)
  • 2020-12-15 08:04

    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.
    (source: friday.com)

    0 讨论(0)
  • 2020-12-15 08:10

    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...".

    0 讨论(0)
  • 2020-12-15 08:11

    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 :-)

    0 讨论(0)
  • 2020-12-15 08:12

    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.

    0 讨论(0)
  • 2020-12-15 08:17

    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

    0 讨论(0)
提交回复
热议问题