When I create an object and check its retain count, I get 1 as expected. When I release the object and then check the retain count again, it is still 1. Shouldn't the object be deallocated, and the retain count 0?
NSMutableString *str=[[NSMutableString alloc] initWithString:@"hello"];
NSLog(@"reference count is %i",[str retainCount]);
[str release];
NSLog(@"reference count is %i",[str retainCount]);
I do see 0 for the retain count if I set str
to nil
first. Why is that?
Don't use
retainCount
, it doesn't do what you expect in most cases.Your second
NSLog
is accessing deallocated memory as an object. In this particular case, that deallocated memory still contains enough of the old data from the NSString that was just freed for the program to not crash when theretainCount
method is called on it. Had you run this withNSZombieEnabled
you would have gotten an error message about sending a message to a deallocated instance.The reason it returns 0 when called for nil is that methods returning integers will always return 0 when called on a nil object.
Do not depend on
retainCount
. And do not care about this. Lots of things may happen under the hood. You only need to ensure that you have released all the things that you owned. If you are trying to be sure that you are not leaking any memory, then use Instrument, not retainCount in NSLog.