一、先谈谈iOS9中新增的几个关键字
1、可以为空nil
// nullable:表示该属性的值可以为空nil
// 书写方式一
@property (nonatomic, copy, nullable) NSString * name1;
// 书写方式二
@property (nonatomic, copy) NSString *_Nullable name2;
// 书写方式三
@property (nonatomic, copy) NSString *__nullable name3;
2、不可以为空nil
// nonnull:表示该属性的值不可以为空 如果给name赋值nil或者NULL,编译器会报一个警告
// wanging:Null passed to a callee that requires a non-null argument
// 书写方式一
@property (nonatomic, copy, nonnull) NSString * name1;
// 书写方式二
@property (nonatomic, copy) NSString *_Nonnull name2;
/** 书写方式三 */
@property (nonatomic, copy) NSString *__nonnull name3;
3、null_resettable: 表示该属性的get方法返回值不能为空
如果属性赋值为空,会报如下警告
Synthesized setter ‘setName:’ for null_resettable property ‘name’ does not handle nil
解决方法:重写该属性的set或者get方法,处理nil的情况
4、null_unspecified: 表示不确定该属性的值是否为空
5、两个宏定义的介绍,这两个宏是从UIButton.h定义文件中找出来的,分别该文件中的开头和结尾,这两个宏定义的意思表示:在这两者之间定义的属性和方法默认是nonnull类型的,也就是不可以赋值为nil或者NULL
#define NS_ASSUME_NONNULL_BEGIN _Pragma("clang assume_nonnull begin")
#define NS_ASSUME_NONNULL_END _Pragma("clang assume_nonnull end")
二、泛型简单介绍
使用场景:
1、在集合(数组、字典、NSSet)中使用泛型比较常见。
2、当声明一个类的时候,类里面的某些属性的类型不确定,才使用泛型。
注意只能修饰方法的调用,好处:1、减少程序员之间的沟通。在编译前就规范了代码,减少bug的出现。2、通过集合取出的对象,直接当做泛型对象使用。可以直接使用点语法。
协变__covariant 表示:子类给父类赋值,即子类强转为父类的类型
逆变__contravariant 表示:父类给子类赋值,即父类强转为子类的类型
@interface Animal<ObjectType> : NSObject
@end
Animal<Animal *> * mal = [[Animal alloc] init];
Animal<Dog *> * dog = [[Animal alloc] init];
// 子类给父类赋值
mal = dog;
当编译这段代码的时候系统会给出这样一个警告:Incompatible pointer types assigning to ‘Animal
@interface Animal<__covariant ObjectType> : NSObject
@end
同理:如果是dog = mal;
@interface Animal<__contravariant ObjectType> : NSObject
@end
三、__kindof的介绍
__kindof:表示当前类或者它子类
__kindof书写格式:
放在类型前面,表示修饰这个类型(__kindof ClassName *)
__kindof :在调用的时候,很清楚的知道返回类型