泛型

touch方法,我们并不陌生,但是(NSSet *)touches , 你是否好奇过,这个是怎么个写法,这就是泛型

-(void)touchesCancelled:(NSSet *)touches withEvent:(UIEvent *)event;

泛型:限制类型

一 : 泛型使用场景

1、在集合(数组,字典,NSSet) 中使用泛型比较常见。
2、当声明一个类,类里面的某些属性的类型不确定,这时候我们才使用泛型。

 eg:@property(nonatomic) ObjectType *language;
 //调用
 Person *p = [[Person alloc] init];
 //泛型没有确定,就是id类型
 p.language = [[IOS alloc] init];
二 :泛型的书写规范:

在类型后面定义泛型

NSMutableArray *datas
三 :泛型修饰

只能修饰方法的调用

 eg :
 [self.data addObject:<#(nonnull id)#>]; //未使用泛型修饰
 [self.data addObject:<#(nonnull NSString *)#>]; //使用泛型修饰
四 : 泛型好处
1、提高开发规范,减少程序员之间的交流。
2、通过集合取出来对象,直接当做泛型对象使用,可以直接“点出”对象的属性。
 eg : self.data[0].length
五 : __covariant 和 __convariant,用来修饰泛型

__covariant(协变):用于泛型数据强转类型,可以向上强转,子类 可以转成 父类 【赋值】
__convariant(逆变):用于泛型数据强转类型,可以向下强转,父类 可以转成 子类

@interface NSArray<__covariant ObjectType> : NSObject 

声明泛型:

 @interface Person<__covariant ObjectType> : NSObject
六 :id 、 instancetype 、 __kindof

创建一个Person类,继承自NSObject,创建一个sonPerson类,继承自Person类
在Person类中 :+(id)person;

<1> id 坏处:

1.不能在编译的时候检查真实类型。
2.返回值,没有提示,就算用NSString类型也不提示警告。

 NSString *p = [SonPerson person];
<2> instancetype : 会自动识别当前对象的类。
 在Person类中 :+(instancetype)person
<3> __kindof :表示当前类或者它的子类
 +(__kindof Person *)person;

__kindof :书写格式
放在类型前面,表示修饰这个类型
__kindof :在调用的时候,很清楚的知道返回类型

eg:
SonPerson *sonPer = [SonPerson person];
<4> 区别比较:

//仅仅表示只能是Person类

 +(Person *)person;
屏幕快照 2018-04-03 下午1.00.59.png

你可能感兴趣的:(泛型)