[UINavigationController retain]: message sent to deallocated instance

前端 未结 3 1799
礼貌的吻别
礼貌的吻别 2021-01-20 11:07

My application crashes when simulating Memory warning in simulator with error:

[UINavigationController retain]: message sent to deallocated instance<

相关标签:
3条回答
  • 2021-01-20 11:54

    It is likely you are using an assign or __unsafe_unretained property somewhere in your code. Delegates should always be of type weak, so that the reference to the delegate object is nil'ed out on deallocation.

    Also, calling:

    [((WPRAppDelegate*) [UIApplication sharedApplication].delegate) startWithFlash];
    

    ... from within another class in your app is a bit of a smell. One that I've had many times. It means you have circular dependencies. Your app delegate is dependent on the class using this code (transitively, if not directly), and this class is dependent on your app delegate. Looking at your Instruments trace, it looks like you have adopted the delegate pattern else where, so you have some experience with decoupling. I would suggest bubbling that message up through a delegate chain, notification, or block.

    0 讨论(0)
  • 2021-01-20 11:58

    Quickfix: insert assert([NSThread isMainThread]); to various places in your code where you access appDelegate.window.rootViewController. This should be done for write- and for read-accesses to the property! This will reveal the culprit. appDelegate.window.rootViewController must not be accessed from any other thread than the main thread.

    Generally, there are these reasons why this may happen:

    1. You are using __unsafe_unretained variables.
    2. You are using an unsafe_unretained property.
    3. You are using non-ARC
    4. You are accessing the same variable from different threads at the same time
    5. You are accessing the same nonatomic, non-weak property from different threads at the same time

    The fix for 1 and 2 is simple: Just don't use unsafe_unretained anymore.

    The fix for 3 is: use ARC instead.

    The fix for 4 and 5: use atomic properties instead, or synchronize access to your iVars. (Note that you must not access iVars from atomic properties directly as this breaks the atomicity.) Alternatively, use the property only from one thread, e.g. only from the main thread.

    In your example, I assume that issue #5 applies. The culprit should be some non-main-thread accessing rootViewController from UIWindow.

    0 讨论(0)
  • 2021-01-20 12:03

    Finally after days of investigations I've found a reason to all these crashes including the one described in "iOS memory warning sent to deallocated UIViewController"

    The problem came out from PHAirViewController project. I still did not find out a real reason, but simply commenting out - (void)dealloc function in PHAirViewController.m file did the magic.

    The main headache I got when was running Instruments to detect NSZombies. All traces were pointing to system classes like UINavigationController, UIImagePickerViewController etc... Due to this I started disabling ARC for parent controllers. In some places it helped but in some it didn't.

    After a lot of voodoo I found out that every class (including system classes) was implementing UIViewCOntroller(PHAirViewController) Category and though - (void)dealloc function was always called on dismissing them.

    Now the only thing left is to understand why this function is generating NSZombies. The interesting thing is that just commenting its content (which have only one line: self.phSwipeHandler = nil) does not have the same effect.

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