Swift基础 - KVC/遍历构造方法

五.KVC构造方法:

  1. KVC构造函数,利用运行时的机制,在运行的时候,给对象动态调用setValue forKey方法,来给属性赋值;
  2. 对象需要实例化成功:须在self初始化完成后调用KVC(也就是super.init()后面)
  3. swift中,int属于OC中的基本数据类型,基本数据类型与KVC不兼容
  4. 基本数据:类型在使用KVC情况下,应使用非可选项并且初始化,需要在给swift中给基本数据类型一个默认值,默认值不能为nil;
  5. 当我们给了初始值的时候,KVC就能找到基本类型属性

综上:KVC赋值的注意点:

  1. super.init()须在KVC方法前调用,完成对象初始化;
  2. swift的KVC不支持基本数据类型,应在KVC前给基本数据类型赋值一个初始值,且不能为nil;
  3. 或者重写
    setValue(value:AnyObject?, forUndefinedKey)key:String)

override setValue(value:AnyObject?, forUndefinedKey key:String)

            {不要调用super方法;
           super的这个方法就是提供一个崩溃,告诉你哪个值没                     
           有赋值}
  1. 如果实现了 forUndefinedKey,会保证 setValuesForKeysWithDictionary继续遍历后续的 key
  2. 父类实现了forUndefinedKey这个方法,子类就可以不实现了
  3. 执行步骤:
  • 先setValue(value:AnyObject?, key:String)
  • 发现属性中某个属性没有的时候,会调用setValue(value:AnyObject?, forUndefinedKey key:String)
  1. 子类的KVC构造函数父类实现了KVC,子类可以不去实现KVC;
  2. 当子类调用KVC时,没有提示,需要强写;

六.便利构造函数:

  1. 便利构造函数的关键字:convenience init?(参数){ }
  2. 便利构造函数可能返回一个nil
  3. 便利构造函数是为一个需要借助于调用self的其他构造函数,而不是super.init
  4. 便利构造函数不可以重写
  5. 便利构造函数能够对传递进来的参数进行判断,如果满足条件,则返回一个值,不满足返回另外一个值(例如nil)
  6. 调用便利构造方法创建的对象,对象本身是可选项,调用属性时,对象后面加个?:p?.name
  7. 子类可以继承父类的便利构造方法,但是不能重写;

你可能感兴趣的:(Swift基础 - KVC/遍历构造方法)