前言:
不知不觉,工作已经交接的差不多了。这段时间一直在休息,在家呆久了难免会怠惰。所以为了激励自己,也为了接下来的面试做准备,我会利用这段难得悠闲的时间来记录下各路大神以及自己总结出的iOS知识。
kvo(key value observing)的原理:
1.当一个对象被观察时,系统会创建这个对象的派生类(即子类)。
2. 系统会在子类里边重写被观察属性的set方法,在重写方法里调用父类set方法和-observeValueForKeyPath:方法通知观察者。
3.删除类中没有被观察属性的set方法。
4.如果这个类中没有被观察的属性,那么移除系统动态创建的派生类。
代码证明:
口说无凭,我们用代码来一步步分析:
![](https://img.haomeiwen.com/i2112843/9208d052c8dd968e.png)
输出结果:
![](https://img.haomeiwen.com/i2112843/16cba46e66c2ff04.png)
不难发现,系统动态创建了NSKVONotifying_Father类。但为什么35行打印的依然是Father类呢?这是因为系统重写了NSKVONotifying_Father的-class方法的返回值。而36行调用的object _getClass()方法返回的是isa指针,这个指针指向的是这个对象所属的类。
讲到这里,有个问题也可以迎刃而解,那就是给age属性赋值时,为什么系统会调用NSKVONotifying_Father的set方法而不是Father的方法呢?原来系统将isa指向了NSKVONotifying_Father类,那么自然就会调用NSKVONotifying_Father类的set方法。
![](https://img.haomeiwen.com/i2112843/4a3f8851ce3687ef.png)
38行我们移除了age属性的观察者
![](https://img.haomeiwen.com/i2112843/5dc02993997c50fa.png)
我们发现系统悄悄的把NSKVONotifying_Father类移除了,这也就验证了原理4的论述。
网友评论