KVOController代码分析和踩坑

KVOController是FaceBook的一个开源库,提供了方便的姿式让你去使用KVO。 github.com/facebook/KV…git

大概的用法以下:github

[self.KVOController observe:target keyPath:keyPath options:NSKeyValueObservingOptionNew block:^(id observer, id object, NSDictionary *change) {
        id newValue = change[NSKeyValueChangeNewKey];
    }];
复制代码

observe操做完成后,observer会在delloc时移除观察,很是方便。数组

咱们来看看KVOController的实现流程:ui

KVOController实现流程

1.Observer会建立一个FBKVOController的属性;spa

2.FBKVOController中包含一个NSMapTable的成员属性,用来存储observer的KVO信息;设计

3.FBKVOController建立一个_FBKVOInfo类型的实例,实例中存储了和KVO操做相关的信息(keypath等),而后将须要观察的对象Target做为Key,_FBKVOInfo的实例加入数组(对同一个Target的不一样keypath的屡次KVO操做)并把数组做为Value,存入步骤2中的mapTable中;code

4.FBKVOController会调用_FBKVOSharedController的单例中的方法,同时将步骤3建立的info和观察的target传入给这个方法,这个单例进行了最终的KVO操做;cdn

5._FBKVOSharedController的单例调用系统KVO方法,将本身做为观察者来观察Target对象。server

在Observer内存被释放,执行dealloc时,其建立的FBKVOController属性的dealloc会经过KVOInfoMap找到全部KVO的对象,并执行移除观察的操做,十分巧妙的设计!对象

可是在使用的过程当中仍是有一些注意事项的: 首先,FBKVOController使用block来传递系统KVO的回调,所以要注意retain cycle。 其次,在使用的过程当中,target不能强引用observer,不然也会造成retain cycle。我在上面的实现流程图中增长了一些标注来讲明这个retain cycle是如何造成的:

retain cycle造成轨迹
红色的箭头表明了内存持有的方向,能够很清楚的看到造成了cycle。
相关文章
相关标签/搜索