Is AutoRelease redundant when using ARC in Objective-C?

后端 未结 2 1024
庸人自扰
庸人自扰 2021-01-16 12:13

I\'m pretty new to Objective-C, as you may gather, and until recently, I hadn\'t really understood the need for all this AutoRelease malarky. I think that\'s mostly because

相关标签:
2条回答
  • 2021-01-16 13:01

    When using ARC, you do not want to do any memory management yourself. Specifically you will not be calling release and auto release because it does it all for you. In fact, the compiler should probably complain if you try to manage memory yourself.

    Instead of [[[Class alloc] init] autorelease]; you'll just call [[Class alloc] init];

    I recommend reading this blog post for some really good background on ARC and memory management in general.

    0 讨论(0)
  • 2021-01-16 13:06

    Well, your understanding is quite correct. With ARC we do not release or autorelease any more. Just have to make sure that we assign nil (or some other reasonable value) to any reference to objects, which we do not need any more. In the worst case we could still constantly consume additional memory but the memory cannot leak any ore.

    And yes, we still maintain autorelease pools for the sake of using framework libraries (linked ones) that may not use ARC.

    To answer your question between the lines about the purpose of autorelease. This applies to non-ARC project only, of course. In the good old days Objective-C did not offer any reference counting but its retain counting. Any allocated memory of objects, that are not retained (or have a retain count of 0) is considered free and may soon be claimed and used by other objects. This means that every object needs to be retained after its allocation, assuming that you want to keep it around. When the object is not used any more then you need to release it. This comes with two risks. Well, alloc does retain it once automatically. 1) You may forget to release an object that is unused. In the worst case you may even loose all references to an object that stays in memory for ever since. 2) You may still refer to an object hat has been released already and then try accessing it which will most likely end in an BAD_EXC exception.

    All this can be quite annoying. In order to get rid of some of these obligations for objects that don't stay around very long, the autorelease was invented. For temporary objects only you alloc it (release-count = 1) and autorelease it. That means that the object will be automatically released (retain count reduced by 1) within the next autorelease circle. But the object remains allocated for your method while it is being executed. Typically the reference variable would be a local one.

    Sample:

    -(void) myMethod{
    
    AClass *someObject = [[[AClass alloc] init] autorelease];
    
    // use the object
    
    // probably hand it to another object if that takes ownership, i.e. add it ot an Array using addObject:
    
    // don't care any more
    
    }
    

    And that not required any more when using ARC.

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