如果您在子类中实现与超类中的私有方法同名的方法,则您的子类方法将在子类的实例上调用。
即,如果您像这样在超类中实现一个方法,而没有在任何地方声明它:
@implementation classA
- (void)doSomething {
NSLog("a");
}
然后,在您的子类实现中,实现一个具有相同名称的方法:
@implementation subclassOfA
- (void)doSomething {
NSLog("b");
}
当您调用doSomething
子类的实例时,将调用子类实现而不是超类实现,因此此示例中的代码将导致“b”打印到控制台。
但是,如果您还想访问该方法的超类实现,则可以使用:
- (void)doSomething {
[super doSomething];
NSLog("b");
}
这也将调用超类实现。如果你得到一个编译错误(由于方法是私有的并且super
似乎没有实现它),你可以使用它[super performSelector:@selector(doSomething)]
来做完全相同的事情。
这是因为 Objective-C 运行时查找方法调用的方式。由于这些方法具有完全相同的方法签名(相同的名称、返回类型和参数 [none]),因此它们被认为是相等的,并且运行时总是在查看超类之前检查对象的类,因此它会找到子类的方法实现第一的。
此外,这意味着您可以这样做:
classA *test = [subclassOfA new];
[test doSomething];
而且,令人惊讶的是,控制台将打印“ b ”(如果您也调用了实现,则为“ absuper
” )。