How to debug EXC_BAD_ACCESS bug

前端 未结 3 1584
孤城傲影
孤城傲影 2020-12-14 01:17

I received an error

EXC_BAD_ACCESS code=2 at0xb0987654

I am wondering how to print out the value at 0xb0987654?

相关标签:
3条回答
  • 2020-12-14 01:33

    To debug an EXC_BAD_ACCESS, you can generally find out the where the dangling pointer is by enabling zombie objects.

    Xcode

    Choose edit scheme, then Diagnostics tab in the Run section, then click the 'Zombie Objects' option.

    AppCode

    Choose edit target, and add the following environment variable:

    NSZombieEnabled=YES
    

    Another cause for EXC_BAD_ACCESS can be infinite recursion, which can be found by adding some logging.

    Update for C++:

    To debug dangling pointers in C++ with the Clang compiler try using Address Sanitizer (ASAN) from Google.

    0 讨论(0)
  • 2020-12-14 01:39

    Identify what you did that caused the crash. Did it crash while view of a particular view controller didLoad or in a delegate method or on a particular action. That will often help to find the object that is casuing the error.

    • Most of the time “NSZombies” can help to identify the dead object. You can enable NSZombies by editing your scheme Product -> Edit Scheme -> Diagnostics.
    • If you still don’t find the root cause then always go backwards from child view controller to parent view controller to see what object needs to be retained or what message needs to be passed properly.
    • Look into Static Analyzer and Instruments for advanced debugging.

    I hope this will help you.

    Regards, Gison

    0 讨论(0)
  • 2020-12-14 01:50

    It looks like maybe you are trying to write onto a code page or something? EXC_BAD_ACCESS is described in /usr/include/mach/exception_types.h:

    #define EXC_BAD_ACCESS          1       /* Could not access memory */
                /* Code contains kern_return_t describing error. */
                /* Subcode contains bad memory address. */
    

    And from kern_return.h:

    #define KERN_PROTECTION_FAILURE         2
                /* Specified memory is valid, but does not permit the
                 * required forms of access.
                 */
    

    You can see WHERE that address is in your binary by doing:

    (lldb) image lookup -va 0xb0987654
    

    But what you really need to figure out is who is trying to write there. If the problem is simple this might tell you what's wrong, but as Jasper suggests, this is probably some use-after-free or other such problem, and the bad actor is long gone by the time you crash. guardmalloc can also sometimes catch this sort of error (you can enable this in Xcode in the Run scheme.)

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