zoukankan      html  css  js  c++  java
  • KVO实现原理

    KVO意为键值观察Key-Value-Observer,本质仍然是观察者模式。

    • 观察者模式的定义:一个目标对象管理所有依赖于它的观察者对象,并在它自身的状态改变时主动通知观察者对象。这个主动通知通常是通过调用各观察者对象所提供的接口方法来实现的。观察者模式较完美地将目标对象与观察者对象解耦。

    当需要检测其他类的属性值变化,但又不想被观察的类知道,有点像FBI监视嫌疑人,这个时候就可以使用KVO了。

    使用观察者模式需要被观察者的配合,当被观察者的状态发生变化的时候通过事先定义好的接口(协议)通知观察者。在KVO的使用中我们并不需要向被观察者添加额外的代码,就能在被观察的属性变化的时候得到通知,这个功能是如何实现的呢?同KVC一样依赖于强大的Runtime机制。

    系统实现KVO有以下几个步骤:

    • 当类A的对象第一次被观察的时候,系统会在运行期动态创建类A的派生类。我们称为B。
    • 在派生类B中重写类A的setter方法,B类在被重写的setter方法中实现通知机制。
    • 类B重写会 class方法,将自己伪装成类A。类B还会重写dealloc方法释放资源。
    • 系统将所有指向类A对象的isa指针指向类B的对象。

    KVO同KVC一样,通过 isa-swizzling 技术来实现。当观察者被注册为一个对象的属性的观察对象的isa指针被修改,指向一个中间类,而不是在真实的类。其结果是,isa指针的值并不一定反映实例的实际类。

    所以不能依靠isa指针来确定对象是否是一个类的成员。应该使用class方法来确定对象实例的类。

    参考https://www.cnblogs.com/zy1987/p/4616764.html

  • 相关阅读:
    RocketMq总结(六) -- 顺序消息
    RocketMq总结(五) -- 消息队列负载均衡和再分配
    RocketMq总结(三) -- 消费者启动 MQClientInstance
    归并排序
    CMS垃圾收集器总结
    桶排序
    快速排序
    ThreadLocal的妙用
    NC_41 找最小的k个数
    RocketMq一条消息存储结构
  • 原文地址:https://www.cnblogs.com/genggeng/p/10656862.html
Copyright © 2011-2022 走看看