KVO
KVO(Key-Value-Observing):翻译成键值观察。它是一种观察者模式的衍生。其基本思想是,对目标对象的某属性添加观察,当该属性发生变化时,通过触发观察者对象实现的KVO接口方法,来自动的通知观察者。
KVO是观察者模式的另一实现,使用了isa混写(isa-swizzling)来实现KVO。
KVO底层实现:
当某个类的对象第一次被观察时,系统就会在运行时动态地创建该类的一个派生类,在这个派生类中重写原类中被观察属性的setter方法,派生类在被重写的setter方法实现真正的通知机制(Person->NSKVONotifying_Person). 派生类重写了 class 方法以“欺骗”外部调用者它就是起初的那个类。然后系统将这个对象的 isa指针指向这个新诞生的派生类,因此这个对象就成为该派生类的对象了,因而在该对象上对 setter的调用就会调用重写的setter,从而激活键值通知机制。此外,派生类还重写了dealloc 方法来释放资源。
KVO的使用场景:
1.实现上下拉刷新控件 content offset
2.webview混合排版 content size
3.监听模型属性实时更新UI
KVO总结
1.动态创建Person的子类使用
2.子类重写setName
3.动态修改了对象的类型
4.还了解到了,KVO不仅可以调用setter方法,还可以调用插入,删除,代替方法.通过对kvo的进一步了解,我们是很清楚KVO底层运用.
KVO与Notification之间的区别:
notification是需要一个发送notification的对象,一般是notificationCenter,来通知观察者。
KVO是直接通知到观察对象,并且逻辑非常清晰,实现步骤简单。
KVC
KVC(Key-value coding)键值编码,就是指iOS的开发中,可以允许开发者通过Key名直接访问对象的属性,或者给对象的属性赋值。而不需要调用明确的存取方法。这样就可以在运行时动态地访问和修改对象的属性。而不是在编译时确定,这也是iOS开发中的黑魔法之一。很多高级的iOS开发技巧都是基于KVC实现的。
KVC底层实现:
(1.)KVC取值:
1.首先按get
2.如果上面的getter没有找到,KVC则会查找countOf
3.如果上面的方法没有找到,那么会同时查找countOf,enumeratorOf,memberOf格式的方法。如果这三个方法都找到,那么就返回一个可以响应NSSet所的方法的代理集合,和上面一样,给这个代理集合发NSSet的消息,就会以countOf,enumeratorOf,memberOf组合的形式调用。
4.如果还没有找到,再检查类方法+(BOOL)accessInstanceVariablesDirectly,如果返回YES(默认行为),那么和先前的设值一样,会按_,_is,,is的顺序搜索成员变量名,这里不推荐这么做,因为这样直接访问实例变量破坏了封装性,使代码更脆弱。如果重写了类方法+(BOOL)accessInstanceVariablesDirectly返回NO的话,那么会直接调用valueForUndefinedKey:方法,默认是抛出异常。
(2.)KVC设值:
1.程序优先调用set
2.如果没有找到setName:方法,KVC机制会检查+(BOOL)accessInstanceVariablesDirectly方法
3.如果该类即没有set
4.和上面一样,如果该类即没有set
5.如果上面列出的方法或者成员变量都不存在,系统将会执行该对象的setValue:forUndefinedKey:方法,默认是抛出异常。
KVC的使用场景:
1.KVC设值
2.KVC取值
3.KVC使用keyPath
4.KVC处理异常
5.KVC处理数值和结构体类型属性
6.KVC键值验证(Key-Value Validation)
7.KVC处理集合
8.KVC处理字典