RxSwift <8> —— dispose源码解析

2019-10-17  本文已影响0人  Gollum_

*销毁者 dispose
上代码:

let ob = Observable<Any>.create { (observer) -> Disposable in
    observer.onNext("hello")
    return Disposables.create {
            print("销毁释放了")
        }
}
// 序列订阅
let dispose = ob.subscribe(onNext: { (anything) in
    print("订阅到了:\(anything)")
}, onError: { (error) in
    print("订阅到了:\(error)")
}, onCompleted: {
    print("完成了")
}) {
    print("销毁回调")
}

进入源码

extension Disposables {
    public static func create(with dispose:) -> Cancelable {
        return AnonymousDisposable(disposeAction: dispose)
    }
}

fileprivate init(disposeAction: @escaping DisposeAction) {
    self._disposeAction = disposeAction
    super.init()
}

// 核心逻辑
fileprivate func dispose() {
    if fetchOr(self._isDisposed, 1) == 0 {
        if let action = self._disposeAction {
            self._disposeAction = nil
            action()
        }
    }
}

销调用
上面的流程,我们是在序列的回调闭包:subscriberHandle里面,其实这个流程之前还有一个非常重要的流程:订阅 subscriber

if let disposed = onDisposed {
  disposable = Disposables.create(with: disposed)  
}else {
  disposable = Disposables.create()
 }
switch event {
case .next(let value):
    onNext?(value)
case .error(let error):
  // 响应外界调回闭包
    disposable.dispose()
case .completed:
  // 响应外界调回闭包
    disposable.dispose()
}

总结

- 无论我们直接销毁还是系统帮助我们销毁必然会调用:dispose()
- 我们查看 dispose() 得出: 就是在初始化初期我们保留的两个属性的操作
- sink.dispose() + self._sink = nil & subscription.dispose() + self._subscription = nil 执行相关释放和销毁
- 如果你细细品来你会慢慢感知到:这种设计是对的!
- 我们在 RxSwift 的世界里最重要的东西,我们就是通过:序列,观察者 来建立响应关系!如果我们断开了响应关系不就达到销毁的目标?然而我们断开响应关系最重要的就是:Sink
上一篇 下一篇

猜你喜欢

热点阅读