当给一个对象添加KVO监听时,KVO会在运行时(runtime)自动创建一个新类,将isa指针指向这个新类,新类是原类的子类,命名规则是NSKVONotifying_xxx的格式。新类内部也有一个set方法,并且重写了class 和 dealloc 方法 ,_isKVOA,之所以重写class方法,是因为苹果不想将此新类暴露出来,并且不希望我们知道NSKVONotifying_xxx内部实现,所以此时通过[xxx class]查看类是看不到NSKVONotifying_xxx的,必须通过object_getClass(xxx)来查看,或者根据指针去查看。新类的set方法内部调用了Foundation的_NSSetXxxValueAndNotify函数(此函数名取决于被改变对象的类型,可以根据方法地址打印查看得知),在_NSSetXxxValueAndNotify内部顺序调用willChangeValueForKey:,父类的set方法,didChangeValueForKey:,而在didChangeValueForKey:内部又会调用监听器的observeValueForKeyPath:ofObject:change:context:监听方法去告诉监听者属性值发生了变化,从而达到监听的目的。
一句话概括KVO的底层原理
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。