small medium large xlarge

26 Jun 2010, 22:44
Nicolas Noël (8 posts)

Taken from chapter 7.

self.window.backgroundColor = [NSColor greenColor]; or ` [self.window setBackgroundColor:[NSColor greenColor]; ` and ` [self.textfield setStringValue:[NSString stringWithFormat:@”Hello, %@!”, NSFullUserName()]]; ` or ` self.textfield.stringValue = [NSString stringWithFormat:@”Hello, %@!”, NSFullUserName()]; `

Same result in both cases.

I understand that in both cases we set properties values.

14 Jul 2010, 10:37
Daniel H Steinberg (97 posts)

This is going to sound like waffling.

In iOS programming the answer is clear. backgroundColor is a property so although the first two snippets are equivalent I would always prefer self.window.backgroundColor to using setBackgroundColor.

In Mac OS X programming backgroundColor is not a property. I would love them to retrofit these classes with properties that are accessible to us. So in that case it is technically correct to use setBackgroundColor although because of the naming conventions the dot notation will work.

I asked an Apple engineer (you’ve heard of him but I haven’t asked his permission to attribute this to him) how he felt about this misuse. He said that this is fine and implies the right thing since there are backgroundColor and setBackgroundColor methods. He did want to make sure that I never used the same sort of shortcut for methods that obviously were different than properties.

So if you have a method with declaration -(void) doSomething, you still could technically call it using self.window.doSomething. This would be wrong as it would imply the wrong thing. If you are sending a message to an object you should use [self.window doSomething], if you are getting or setting an (let us say) informal property you can use self.window.backgroundColor.

By informal property I mean a pair of getter and setter methods that are clearly backed by some ivar.

17 Sep 2010, 20:27
Nicolas Noël (8 posts)

Thanks for taking the time to reply.


You must be logged in to comment