Is it safe in Objective-C to write
self.propery = [[SomeClass alloc] init];
instead of
SomeClass *tmp = [[SomeClass alloc] init];
self.property = tmp;
[tmp release];
or will the first form leak memory?
Is it safe in Objective-C to write
self.propery = [[SomeClass alloc] init];
instead of
SomeClass *tmp = [[SomeClass alloc] init];
self.property = tmp;
[tmp release];
or will the first form leak memory?
It depends on how the property is defined. If it's defined with retain or copy then, yes, your first example will leak.
The first example leaks unless you provide a custom property setter. You can use:
self.propery = [[[SomeClass alloc] init] autorelease];
Instead.
It doesn't make a bit of difference whether or not your property is defined as retain, copy, or assign. When you create a local instance of a class with [[SomeClass alloc] init]
, you are responsible for releasing it within the scope it was created.
Kevin's response is correct. If you do not feel like creating, setting, releasing - you can use autorelease. The main autorelease pool is drained from time to time, you will not be using that memory for the lifetime of the application.
It is worth noting that the unpredictable nature of autorelease pools means that you can not be sure when that memory will be released. If working in a memory constrained platform like the iPhone, you should avoid using autorelease except in places where necessary.