I would like to know in what situation did you use -retainCount
so far, and eventually the problems that can happen using it.
Thanks.
I would like to know in what situation did you use -retainCount
so far, and eventually the problems that can happen using it.
Thanks.
You should never use
-retainCount
, because it never tells you anything useful. The implementation of the Foundation and AppKit/UIKit frameworks is opaque; you don't know what's being retained, why it's being retained, who's retaining it, when it was retained, and so on.For example:
[NSNumber numberWithInt:1]
would have aretainCount
of 1. It doesn't. It's 2.@"Foo"
would have aretainCount
of 1. It doesn't. It's 1152921504606846975.[NSString stringWithString:@"Foo"]
would have aretainCount
of 1. It doesn't. Again, it's 1152921504606846975.Basically, since anything can retain an object (and therefore alter its
retainCount
), and since you don't have the source to most of the code that runs an application, an object'sretainCount
is meaningless.If you're trying to track down why an object isn't getting deallocated, use the Leaks tool in Instruments. If you're trying to track down why an object was deallocated too soon, use the Zombies tool in Instruments.
But don't use
-retainCount
. It's a truly worthless method.edit
Please everyone go to http://bugreport.apple.com and request that
-retainCount
be deprecated. The more people that ask for it, the better.edit #2
As an update,
[NSNumber numberWithInt:1]
now has aretainCount
of 9223372036854775807. If your code was expecting it to be 2, your code has now broken.NEVER!
Seriously. Just don't do it.
Just follow the Memory Management Guidelines and only release what you
alloc
,new
orcopy
(or anything you calledretain
upon originally).@bbum said it best here on SO, and in even more detail on his blog.
You should not be worrying about memory leaking until your app is up and running and doing something useful.
Once it is, fire up Instruments and use the app and see if memory leaks really happen. In most cases you created an object yourself (thus you own it) and forgot to release it after you were done.
Don't try and optimize your code as you are writing it, your guesses as to what may leak memory or take too long are often wrong when you actually use the app normally.
Do try and write correct code e.g. if you create an object using alloc and such, then make sure you release it properly.
Autoreleased objects are one case where checking -retainCount is uninformative and potentially misleading. The retain count tells you nothing about how many times -autorelease has been called on an object and therefore how many time it will be released when the current autorelease pool drains.
I do find retainCounts very useful when checked using 'Instruments'.
Using the 'allocations' tool, make sure 'Record reference counts' is turned on and you can go into any object and see its retainCount history.
By pairing allocs and releases you can get a good picture of what is going on and often solve those difficult cases where something is not being released.
This has never let me down - including finding bugs in early beta releases of iOS.