本文介绍: 当被添加以后,系统会利用派生一个[NSKVONotifyin_Person]作为监听[Person]的子类。他的指针指向Person类,并且内部会重新对属性方法重写。并且派生类中会重写监听属性方法重写class方法、重写dealloc方法和_isKVOA方法等。且方法内部顺序调用方法,原来的方法、方法,而方法内部又会调用监听器的observeValueForKeyPath:ofObject:change:context:监听方法。如果只单单调用是不会生效,所有在该方法内部会有判断是否调用方法在先1:

KVO本质

对象被添加KVO以后,系统会利用runtime派生一个[NSKVONotifyin_Person]作为监听[Person]的子类。他的superclass指针指向Person类,并且NSKVONotifyin_Person内部会重新对属性setter方法重写。并且派生类中会重写监听属性setter方法、重写class方法、重写dealloc方法和_isKVOA方法等。且set方法内部顺序调用willChangeValueForKey方法,原来的setter方法、didChangeValueForKey方法,而didChangeValueForKey方法内部又会调用监听器的observeValueForKeyPath:ofObject:change:context:监听方法。如果只单单调用didChangeValueForKey是不会生效,所有在该方法内部会有判断是否调用willChangeValueForKey方法在先

派生类各个方法返回定义

1:其中class方法时返回监听类的类对象
2:dealloc是及时释放派生类的中kvo对象(可能是)
3:_isKVOA 直接放回YES

调用KVO顺序如下

1: willChangeValueForKey
2:父类setter方法
3:didChangeValueForKey
即可触发KVO

可以来微信公众号(洲洲哥)后台给我留言。 快来扫码关注我们吧!

公众号二维码

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注