I want to create a method like this:
- (void) checkAndUpdateStringProperty: (NSString **) property{
if (...)
*property = @\"whatever\";
}
>
Properties should only ever be accessed through their getter and setter methods, with the exception of initializing and deinitializing them in the object's init
and dealloc
methods (when the object is not in a fully consistent state) -- accessing them any other way defeats their purpose and does not respect their attributes (retain
, copy
, etc.).
The reason why it doesn't compile is because property accessors are syntactic sugar for method calls, and you can't take the address of the return value of a method. self.productName
is identical to [self productName]
, and &[self productName]
makes no sense.
If you really want to do this, don't do it with a property, do it with just a regular variable (such as a local variable or ivar), and document the semantics of your function: does the calling function need to release
the returned object? Etc. For example, the various Apple methods which take an NSError**
specify that the error object which is returned, if any, is an autoreleased object, so you should not release
it yourself unless you also retain
it.