touch
方法,我们并不陌生,但是(NSSet<UITouch *> *)touches
, 你是否好奇过,这个是怎么个写法,这就是泛型
-(void)touchesCancelled:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event;
泛型:限制类型
一 : 泛型使用场景
1、在集合(数组,字典,NSSet) 中使用泛型比较常见。
2、当声明一个类,类里面的某些属性的类型不确定,这时候我们才使用泛型。
eg:@property(nonatomic) ObjectType *language;
//调用
Person<IOS *> *p = [[Person alloc] init];
//泛型没有确定,就是id类型
p.language = [[IOS alloc] init];
二 :泛型的书写规范:
在类型后面定义泛型
NSMutableArray<UITouch *> *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 <NSCopying, NSMutableCopying, NSSecureCoding, NSFastEnumeration>
声明泛型:
@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;