KVO实现原理

本文详细解释了KVO(Key-ValueObserving)的工作原理,包括runtime如何动态创建派生类重写setter方法,以及为何直接赋值成员变量不会触发KVO通知。重点强调了setter方法在KVO中的关键作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

        KVO是基于runtime机制实现的。当某个类的属性对象第一次被观察时,系统就会在运行期动态地创立该类的一个派生类,在这个派生类中重写基类中任何被观察属性的setter方法。派生类在被重写的setter方法内实现真正的通知机制。

        以Person类为例,那么生成的派生类名为NSKVONotifying_Person。

        当某个属性第一次被观察,那么系统会偷偷将其isa指针从原来的类,改为指向动态生成的派生类,从而使得属性被赋值时执行的是派生类的setter方法。

        在派生类重写的settter方法中, 通过NSObject的 willchangeValueforKey、didchangeValueForKey等方法通知外部观察者,继而使得观察者的observeValueForKey:ofObject:change:context:方法被调用。

//NSKVONotifying_Person的setter方法
- (void) setValue: (id) obj{
    [self willChangeValueForKey:@"keyPath"];
    [super setValue: obj];
    [self didChangeValueForKey:@"keyPath"];
}

        问题: 通过给成员变量直接赋值,而不是通过属性修改成员变量在变量值变化时收到通知?

        答案是否定的。因为kvo是重写的setter方法,成员变量赋值只是修改指针的引用,并不会调用setter方法。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值