五.KVC构造方法:
- KVC构造函数,利用运行时的机制,在运行的时候,给对象动态调用setValue forKey方法,来给属性赋值;
- 对象需要实例化成功:须在self初始化完成后调用KVC(也就是super.init()后面)
- swift中,int属于OC中的基本数据类型,基本数据类型与KVC不兼容
- 基本数据:类型在使用KVC情况下,应使用非可选项并且初始化,需要在给swift中给基本数据类型一个默认值,默认值不能为nil;
- 当我们给了初始值的时候,KVC就能找到基本类型属性
综上:KVC赋值的注意点:
- super.init()须在KVC方法前调用,完成对象初始化;
- swift的KVC不支持基本数据类型,应在KVC前给基本数据类型赋值一个初始值,且不能为nil;
- 或者重写
setValue(value:AnyObject?, forUndefinedKey)key:String)
override setValue(value:AnyObject?, forUndefinedKey key:String)
{不要调用super方法;
super的这个方法就是提供一个崩溃,告诉你哪个值没
有赋值}
- 如果实现了 forUndefinedKey,会保证 setValuesForKeysWithDictionary继续遍历后续的 key
- 父类实现了forUndefinedKey这个方法,子类就可以不实现了
- 执行步骤:
- 先setValue(value:AnyObject?, key:String)
- 发现属性中某个属性没有的时候,会调用setValue(value:AnyObject?, forUndefinedKey key:String)
- 子类的KVC构造函数父类实现了KVC,子类可以不去实现KVC;
- 当子类调用KVC时,没有提示,需要强写;
六.便利构造函数:
- 便利构造函数的关键字:convenience init?(参数){ }
- 便利构造函数可能返回一个nil
- 便利构造函数是为一个需要借助于调用self的其他构造函数,而不是super.init
- 便利构造函数不可以重写
- 便利构造函数能够对传递进来的参数进行判断,如果满足条件,则返回一个值,不满足返回另外一个值(例如nil)
- 调用便利构造方法创建的对象,对象本身是可选项,调用属性时,对象后面加个?:p?.name
- 子类可以继承父类的便利构造方法,但是不能重写;