关键字
- iOS9新出的关键字:用来修饰属性,或者方法的参数,方法的返回值
- 好处:
- 迎合swift
- 提高我们开发人员开发规范,减少程序员之间交流
- 注意: iOS9新出关键字nonnull,nullable,null_resettable,_Null_unspecified只能
修饰对象,不能修饰基本数据类型
/**
1. 首字母不带下滑线的修饰类名(eg. nullable)
2. 首字母带一个下划线,则首字母大写,修饰对象(eg. _Nullable)
3. 首字母带两个下划线,则首字母小写,修饰对象(eg. __nullable)
4. 大多数一般只有第一种
*/
nullable
作用:表示可以为空
nullable书写规范:
// 方式一:
@property (nonatomic, strong, nullable) NSString *name;
// 方式二:
@property (nonatomic, strong) NSString *_Nullable name;
// 方式三:
@property (nonatomic, strong) NSString *__nullable name;
nonnull
作用:不能为空
nonnull: non:非 null:空
书写格式:
@property (nonatomic, strong, nonnull) NSString *icon;
@property (nonatomic, strong) NSString * _Nonnull icon;
@property (nonatomic, strong) NSString * __nonnull icon;
在NS_ASSUME_NONNULL_BEGIN
和NS_ASSUME_NONNULL_END
之间,定义的所有对象属性和方法默认都是nonnull
null_resettable
作用: get:不能返回为空, set可以为空
// 书写方式:
@property (nonatomic, strong, null_resettable) NSString *name;
// 注意;如果使用null_resettable,必须 重写get方法或者set方法,处理传递的值为空的情况
_Null_unspecified
作用:不确定是否为空
// 书写方式只有这种
// 方式一
@property (nonatomic, strong) NSString *_Null_unspecified name;
// 方式二
@property (nonatomic, strong) NSString *__null_unspecified name;
泛型(限制类型)
使用场景
- 限制集合中的类型(数组、字典、NSSet)
注意:只能检测方法的调用,因为声明的泛型,只能放在方法中 - 当一个类在声明的时候,某个对象的属性不确定,只有创建对象的时候才确定,可以使用泛型
好处
- 提高开发规范,减少程序员之间交流
- 通过集合取出来对象,直接当做泛型对象使用,可以直接使用点语法
书写格式
放在类型后面,表示限制这个类型。
@property (nonatomic, strong) NSMutableArray<NSString *> *datas;
自定义泛型:模仿数组
- 需求:假设有个Person,这个人会编程语言,但是在定义的时候不确定,只有在创建对象的时候才确定。
- language属性的类型就有讲究了
- id 类型:表示可以传任何对象
- Launguage类型,在赋值的时候没有提示
- 泛型,声明泛型,在创建对象的时候,确定泛型,在赋值就有提示了。
@interface Person<ObjectType> : NSObject {
// 语言
@property (nonatomic) ObjectType language;
}
协变,逆变
作用:用于转换类型
- 默认带有泛型的变量,互相赋值有报警告,使用协变,逆变,就能解决.
- 协变(__covariant): 向上转型, 子类转父类
- 逆变(__contravariant):向下转型 父类转子类
__kindof
id坏处
- 不能在编译的时候检查真实类型
- 返回值,没有提示
- 可以调用任何方法,编译时不报错
instancetype
- 会自动识别当前对象的类,返回当前调用类的对象
+ (instancetype)person;
__kindof :
在调用的时候,很清楚的知道返回类型(类似于instancetype,但instancetype只能用于初始化中)
作用:
1. 将此类型指定为class_name或class_name的子类,告诉编译器这两者均能适配。
2. Objective-C是动态类型,编译器会在编译时做类型匹配,不会有编译警告,更不会报错。
场景:
1. 泛型
2. 方法返回值
//
- (nullable __kindof UITableViewCell *)cellForRowAtIndexPath:(NSIndexPath *)indexPath; visible or index path is out of range;
// returns nil if cell is not
@property (nonatomic, readonly) NSArray<__kindof UITableViewCell *> *visibleCells;