In the following function which one is the best practice?
-
To send an autoreleased object, and make the caller retain it?
-
or send an allocated object, and make the caller release it?
- (NSString*) convertDataToString :(NSData*)myData
{
//just an example, method might not exist
NSString *str = [[NSString alloc] initWithData:myData];
return str;
return [str autoRelease];
}
The memory management rules say your first example is — and this is a direct quote — wrong. It’s not even a matter of preference, as some answers here seem to indicate. The caller does not normally own the object you return, so it should be autoreleased.
The specific example from the rules says this: