What does “Autoreleased with no pool in place” mean?

前端 未结 2 877
既然无缘
既然无缘 2021-02-15 14:36

My Application structure is as follows, the core part is written in C++ and using thread heavily, and i am developing UI in Objective C on top of it, if i don\'t execute the t

相关标签:
2条回答
  • 2021-02-15 14:56

    See these docs for what you should know about multithreading with Cocoa: http://developer.apple.com/library/mac/#documentation/Cocoa/Conceptual/Multithreading/ThreadSafetySummary/ThreadSafetySummary.html

    It's OK to design your app like you have, but two things should be kept in mind:

    1. Life is simplest (and sometimes necessary) when UI controls like views (AppKit or UIKit) are manipulated on the main thread. You can use Foundation objects and some AppKit/UIKit objects on background threads, and some Foundation objects can be used from multiple threads.
    2. If you're using any Cocoa objects at all in background threads, you'll need to set up autorelease pools on those threads.

    Like so:

    - (void)backgroundThreadStart 
    {
        NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init];
    
        // do stuff
    
        [pool release];
    }
    

    That will fix your console errors, but you might have other issues that led to the actual crashing you were seeing.

    0 讨论(0)
  • 2021-02-15 15:10

    It means you autoreleased something without an autorelease pool in place.

    Every thread has a stack of autorelease pools. On the main thread, an autorelease pool is created for you before Cocoa calls out to your code, and drained after your code returns. Every object you autorelease (whether explicitly or implicitly) goes into the pool, so that the pool will release it when the pool gets drained. When you create a thread, you have to create and drain an autorelease pool on that thread yourself. (Or just not autorelease anything, but that's practically impossible for any meaningful amount of code.)

    If you ever decide to run your code under garbage-collection, you'll need to send the pool drain, not release, when you're done with it, for the pool to be useful. When GC is enabled, release and autorelease messages do nothing—they don't even go through. Your autorelease pool will respond to drain by poking the garbage collector, which is the nearest equivalent to releasing the objects that would have been in the pool.

    The Memory Management Programming Guide for Cocoa has more information about autorelease pools, among other things.

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