As an example, when I’m using an NSMutableDictionary, I know it inherits all the methods of NSDictionary, but how can I know/trust that it has overridden the behavior of those methods if I want to use NSDictionary methods (such as +dictionaryWithObjectsAndKeys) to create my mutable dictionary instance?
More generally, is it the Framework’s responsibility to make sure subclasses don’t blindly inherit methods that can potentially break instances of the subclass if used? Or is it the coder’s responsibility to know not to use them? If Square inherits from Rectangle, and via inheritance I can call
Square *newSquare = [[Square alloc] init];
[newSquare setWidth:3 andHeight:6]; //instead of -(void)setSide:(int)side
I’ve “broken” the square and other methods which depend on width being equal to height will not work now. What are the rules of the game?
The rule would be only expose what you would allow to be override it means, put on your interface what is really public. When necessary explicitly state that when overriding an specific method call at some point [super methodName].
On your example you would override the method
- (void)setWidth:(int)width andHeight:(int)height, and you would like to throw an error ifwidth != height. Or you could also throw an error and force the user to only use- (void)setSide:(int)side.For example you could do:
If you would like to throw some errors and warnings at compilation time, you could use on the declaration of your methods, some of the macros defined on
NSObjCRuntime.h.