不同于C++
拥有强大的多继承
特性,OC
只支持单继承
,但是OC
真的就放弃了如此强大的多继承
特性了么?答案是否定的。
虽然在语法上OC
不支持多继承
,但是OC
提供了另外的方法间接实现类的多继承
OC实现多继承的途径。
举例:ClassA,ClassB,ClassC 三个类,ClassC继承ClassA和ClassB。
- 通过组合的方式实现多继承
这种方式最简单粗暴,在子类
中创建父类对象
,外部调用时让父类对象
去调用父类方法
,从而实现多继承
。
#import "ClassC.h"
#import "ClassA.h"
#import "ClassB.h"
@interface ClassC ()
@property (nonatomic, strong) ClassA *a;
@property (nonatomic, strong) ClassB *b;
@end
@implementation ClassC
- (instancetype)init {
self = [super init];
if (self) {
_a = [[ClassA alloc]init];
_b = [[ClassB alloc]init];
}
return self;
}
- (void)classCMethod{
NSLog(@"调用了classCMethod");
}
- (void)classBMethod {
NSLog(@"调用了classBMethod");
}
- (void)classAMethod {
NSLog(@"调用了classAMethod");
}
// 调用
ClassC *c = [[ClassC alloc]init];
[c classAMethod];
// 打印结果
调用了classAMethod
- 通过协议实现多继承
因为OC
允许一个类遵守多个协议
,所以我们可以通过协议
的方式模拟多继承
。但是协议
只能提供接口
,不能提供实现
,所以我们需要在子类
中添加对应的实现
,这也注定了协议
实现多继承
是不完美的。
// ClassA.h
@protocol ClassADelegate <NSObject>
- (void)classAMethod;
@end
// ClassB.h
@protocol ClassBDelegate <NSObject>
- (void)classBMethod;
@end
// ClassC.h
#import "ClassA.h"
#import "ClassB.h"
@interface ClassC : NSObject <ClassADelegate,ClassBDelegate>
- (void)classCMethod;
@end
// ClassC.m
- (void)classCMethod{
NSLog(@"调用了classCMethod");
}
- (void)classBMethod {
NSLog(@"调用了classBMethod");
}
- (void)classAMethod {
NSLog(@"调用了classAMethod");
}
// 调用
ClassC *c = [[ClassC alloc]init];
[c classAMethod];
// 打印结果
调用了classAMethod
3.通过分类Category实现多继承
具体可见我的另一篇文章 分类Category & 扩展 Extension