本文介绍: 当被添加以后,系统会利用派生一个[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
可以来微信公众号(洲洲哥)后台给我留言。 快来扫码关注我们吧!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。