RxSwift核心逻辑(二)

3 篇文章 0 订阅
2 篇文章 0 订阅

一.序列继承链

 

    Observable遵循了ObservableType,通过查看Create.swift文件的源码发现ObservableType通过扩展添加了方法create。

extension ObservableType {
    public static func create(_ subscribe: @escaping (AnyObserver<E>) -> Disposable) -> Observable<E> {
        return AnonymousObservable(subscribe)    //返回了一个匿名序列
    }
}

    create方法里面返回了一个匿名序列:AnonymousObservable, AnonymousObservable的源码:

final private class AnonymousObservable<Element>: Producer<Element> {
    typealias SubscribeHandler = (AnyObserver<Element>) -> Disposable

    let _subscribeHandler: SubscribeHandler

    init(_ subscribeHandler: @escaping SubscribeHandler) {
        self._subscribeHandler = subscribeHandler    //初始化的时候吧传进来的闭包进行保存一下
    }

    override func run<O : ObserverType>(_ observer: O, cancel: Cancelable) -> (sink: Disposable, subscription: Disposable) where O.E == Element {
        let sink = AnonymousObservableSink(observer: observer, cancel: cancel)   //管道,可以理解为一个统一管理的
        let subscription = sink.run(self)
        return (sink: sink, subscription: subscription)
    }
}

    AnonymousObservable是一个类(class),这个匿名序列继承自Producer,这个 Producer很重要!!!

class Producer<Element> : Observable<Element> {
    override init() {
        super.init()
    }

    //重写父类的subscribe方法,订阅事件
    override func subscribe<O : ObserverType>(_ observer: O) -> Disposable where O.E == Element {
       ...
    }
    //运行
    func run<O : ObserverType>(_ observer: O, cancel: Cancelable) -> (sink: Disposable, subscription: Disposable) where O.E == Element {
        rxAbstractMethod()
    }
}

    Producer继承于ObservableObservable是可观察序列,遵循ObservableType协议,我们的终极序列,所有序列的基类,ObservableType协议定义了一个函数subscribe,所有遵循这个协议的序列都具有subscribe的功能。

public class Observable<Element> : ObservableType {
    /// Type of elements in sequence.
    public typealias E = Element
    
    init() {
#if TRACE_RESOURCES
        _ = Resources.incrementTotal()  //rxSwift自己的引用计数,创建就会提升,销毁就会下降
#endif
    }
    
    //订阅事件
    public func subscribe<O: ObserverType>(_ observer: O) -> Disposable where O.E == E {
        rxAbstractMethod()    //抽象方法,没有实现
    }
    
    public func asObservable() -> Observable<E> {    //???
        return self
    }
    
    deinit {
#if TRACE_RESOURCES
        _ = Resources.decrementTotal()   //根据这个可以知道是否存在内存问题
#endif
    }
   ...
}

    Observable类本来就是一个可观察序列,为什么突然又出现一个asObservable函数呢??

为了统一管理,万物皆序列。比如:UISwitch().rx.value,虽然UISwitch也可以.出rx.出value,但是查看value的底层

public var value: RxCocoa.ControlProperty<Bool> { get }   //是ControlProperty类型的

public struct ControlProperty<PropertyType> : ControlPropertyType {  //遵循了ControlPropertyType协议
    public typealias E = PropertyType
    ...
}

public protocol ControlPropertyType : ObservableType, ObserverType {   //遵循了ObservableType协议

    /// - returns: `ControlProperty` interface
    func asControlProperty() -> ControlProperty<E>
}

    遵循了ObservableType,也可以订阅事件,但是它始终不是Observable对象,为了规范统进行转化。类似于“as”的强转功能。

    综述:序列Observable提供普遍功能,有asObservable,提供subscribe接口,使得所有继承于Observable的序列都具有订阅的功能。

二.订阅者继承链和订阅流程

   上一篇文章《函数响应编程&RxSwift(一)》提到序列Observablesubscribe订阅的时候会创建一个observer订阅者。

 public func subscribe(onNext: ((E) -> Void)? = nil, onError: ((Swift.Error) -> Void)? = nil, onCompleted: (() -> Void)? = nil, onDisposed: (() -> Void)? = nil)
        -> Disposable {
            let disposable: Disposable
           ...
            //创建一个匿名订阅者,这个E是调用者传过来的一个序列类型
            let observer = AnonymousObserver<E> { event in
                
                #if DEBUG
                    synchronizationTracker.register(synchronizationErrorMessage: .default)
                    defer { synchronizationTracker.unregister() }
                #endif
                
                ...
            }
            return Disposables.create(
                self.asObservable().subscribe(observer),
                disposable
            )
    }
}

    AnonymousObserver的源代码:

final class AnonymousObserver<ElementType> : ObserverBase<ElementType> {
    typealias Element = ElementType
    
    typealias EventHandler = (Event<Element>) -> Void
    
    private let _eventHandler : EventHandler
    
    init(_ eventHandler: @escaping EventHandler) {
#if TRACE_RESOURCES
        _ = Resources.incrementTotal()
#endif
        self._eventHandler = eventHandler
    }

    override func onCore(_ event: Event<Element>) {
        return self._eventHandler(event)
    }
    
#if TRACE_RESOURCES
    deinit {
        _ = Resources.decrementTotal()
    }
#endif
}

AnonymousObserver继承于ObserverBase,ObserverBase源码如下:

class ObserverBase<ElementType> : Disposable, ObserverType {
    typealias E = ElementType

    private let _isStopped = AtomicInt(0)

    func on(_ event: Event<E>) {    //实现协议ObserverType的方法,Event是一个枚举类型
        switch event {
        case .next:
            if load(self._isStopped) == 0 {
                self.onCore(event)
            }
        case .error, .completed:
            if fetchOr(self._isStopped, 1) == 0 {
                self.onCore(event)
            }
        }
    }

    func onCore(_ event: Event<E>) {
        rxAbstractMethod()
    }

    func dispose() {
        fetchOr(self._isStopped, 1)
    }
}

ObserverBase具有不断发送信号的功能,ObserverType是一个协议,源码如下

public protocol ObserverType {
    /// The type of elements in sequence that observer can observe.
    associatedtype E   //关联类型

    /// Notify observer about sequence event.
    ///
    /// - parameter event: Event that occurred.
    func on(_ event: Event<E>)    //协议方法
}

    subscribe中的“self.asObservable().subscribe(observer)”到底有谁来进行调用呢?

    不知道它是什么类型,但是为了统一,所以调用了asObservable,调用subscribe方法。AnonymousObservable里面没有subscribe方法,那么就开始去查找他的父类ProducerProducer继承了Observable,并且实现了subscribe这个抽象类的实现。再看一下Producer的源码

class Producer<Element> : Observable<Element> {
    override init() {
        super.init()
    }

    //重写父类的抽象方法subscribe
    override func subscribe<O : ObserverType>(_ observer: O) -> Disposable where O.E == Element {
        if !CurrentThreadScheduler.isScheduleRequired {  //CurrentThreadScheduler调度者
            // The returned disposable needs to release all references once it was disposed.
            let disposer = SinkDisposer()
            let sinkAndSubscription = self.run(observer, cancel: disposer)
            disposer.setSinkAndSubscription(sink: sinkAndSubscription.sink, subscription: sinkAndSubscription.subscription)

            return disposer //返回销毁者
        }
        else {
            return CurrentThreadScheduler.instance.schedule(()) { _ in
                let disposer = SinkDisposer()
                let sinkAndSubscription = self.run(observer, cancel: disposer)
                disposer.setSinkAndSubscription(sink: sinkAndSubscription.sink, subscription: sinkAndSubscription.subscription)

                return disposer
            }
        }
    }

    func run<O : ObserverType>(_ observer: O, cancel: Cancelable) -> (sink: Disposable, subscription: Disposable) where O.E == Element {
        rxAbstractMethod()
    }
}

    Producer统一处理避免子类的下发产生冗余代码,且并不影响基类,基类也不需要关心具体的实现。具体的run方法实现应该由子类单独去处理,体现出RxSwift的分工非常的明确。这里使用的AnonymousObersevable,所以具体的run实现源码在AnonymousObersevable里面,源码如下:

final private class AnonymousObservable<Element>: Producer<Element> {
   ...
    override func run<O : ObserverType>(_ observer: O, cancel: Cancelable) -> (sink: Disposable, subscription: Disposable) where O.E == Element {
        //管子
        let sink = AnonymousObservableSink(observer: observer, cancel: cancel)
        let subscription = sink.run(self)
        return (sink: sink, subscription: subscription)
    }
}

三.核心重点

AnonymousObservable会调用父类Producersubscribe函数,subscribe函数内,会调用AnonymousObservable具体的run方法,AnonymousObservable的run函数源码:

  override func run<O : ObserverType>(_ observer: O, cancel: Cancelable) -> (sink: Disposable, subscription: Disposable) where O.E == Element {
        let sink = AnonymousObservableSink(observer: observer, cancel: cancel)
        let subscription = sink.run(self)
        return (sink: sink, subscription: subscription)
    }

AnonymousObservableSink继承于SinkSink中就有observer和cancel这两个属性,在此进行保存。

class Sink<O : ObserverType> : Disposable {
    fileprivate let _observer: O
    fileprivate let _cancel: Cancelable
    fileprivate let _disposed = AtomicInt(0)
    ...
    init(observer: O, cancel: Cancelable) {
#if TRACE_RESOURCES
        _ = Resources.incrementTotal()
#endif
        self._observer = observer
        self._cancel = cancel
    }
    ...
}

run函数中,sink调用了AnonymousObservable本类重的run函数。

func run(_ parent: Parent) -> Disposable {
   return parent._subscribeHandler(AnyObserver(self))   //讲当前的序列传递过去
}

typealias Parent = AnonymousObservable<E>

因此,Sink这个管子拥有了 订阅者销毁者序列调度环境,处理的就是具体的业务逻辑。

查看AnonymousObservableSink的源码:

final private class AnonymousObservableSink<O: ObserverType>: Sink<O>, ObserverType {
    typealias E = O.E
    typealias Parent = AnonymousObservable<E>

...

    func run(_ parent: Parent) -> Disposable {
        return parent._subscribeHandler(AnyObserver(self))
    }
}
 public static func create(_ subscribe: @escaping (AnyObserver<E>) -> Disposable) -> Observable<E> {
        //subscribe外界传入进来的闭包,传递给AnonymousObservable
        return AnonymousObservable(subscribe)   
 }

final private class AnonymousObservable<Element>: Producer<Element> {
    typealias SubscribeHandler = (AnyObserver<Element>) -> Disposable

    let _subscribeHandler: SubscribeHandler

    //初始化
    init(_ subscribeHandler: @escaping SubscribeHandler) {
        //属性保存此闭包
        self._subscribeHandler = subscribeHandler
    }

    override func run<O : ObserverType>(_ observer: O, cancel: Cancelable) -> (sink: Disposable, subscription: Disposable) where O.E == Element {
        let sink = AnonymousObservableSink(observer: observer, cancel: cancel)
        let subscription = sink.run(self)
        return (sink: sink, subscription: subscription)
    }
}

这里的parent就是我们的序列AnonymousObservable,调用_subscribeHandler函数就是我们一开始creat序列的时候外界传入的闭包。

run函数中_subscribeHandler(AnyObserver(self))重的AnyObserver(self)是什么呢?是不是AnonymousObserver呢?

答案不是的。

AnyObserver是一个结构体,相当于一个序列化器,源码如下:

public struct AnyObserver<Element> : ObserverType {
    /// The type of elements in sequence that observer can observe.
    public typealias E = Element
    
    /// Anonymous event handler type.
    public typealias EventHandler = (Event<Element>) -> Void

    private let observer: EventHandler

...
    public init<O : ObserverType>(_ observer: O) where O.E == Element {
        //这里的observer就是我们传进来的sink,当前的observer是一个函数
        self.observer = observer.on   
    }
    
    /// Send `event` to this observer.
    ///
    /// - parameter event: Event instance.
    public func on(_ event: Event<Element>) {
        return self.observer(event)
    }

    /// Erases type of observer and returns canonical observer.
    ///
    /// - returns: type erased observer.
    public func asObserver() -> AnyObserver<E> {
        return self
    }
}

observer.on就是调用了管子的on函数,核心逻辑就在AnonymousObservableSink里面,源码:

final private class AnonymousObservableSink<O: ObserverType>: Sink<O>, ObserverType {
    typealias E = O.E
    typealias Parent = AnonymousObservable<E>

   ...
    func on(_ event: Event<E>) {
        #if DEBUG
            self._synchronizationTracker.register(synchronizationErrorMessage: .default)
            defer { self._synchronizationTracker.unregister() }
        #endif
        switch event {
        case .next:
            if load(self._isStopped) == 1 {
                return
            }
            self.forwardOn(event)
        case .error, .completed:
            if fetchOr(self._isStopped, 1) == 0 {
                self.forwardOn(event)
                self.dispose()
            }
        }
    }
...
}

AnyObserver这个结构体遵循了ObserverType协议,因此它也有onNext这个方法,而onNext这个方法就是调用了on函数,而这个on函数也就是调用的传进来的管子AnonymousObservableSinkon函数块,订阅者已经加载完毕。

extension ObserverType {

    public func onNext(_ element: E) {
        self.on(.next(element))
    }
   ...
}

管子中的self.forwardOn(event)函数调用了父类SinkforwardOn函数:

final func forwardOn(_ event: Event<O.E>) {
        #if DEBUG
            self._synchronizationTracker.register(synchronizationErrorMessage: .default)
            defer { self._synchronizationTracker.unregister() }
        #endif
        if isFlagSet(self._disposed, 1) {
            return
        }
        self._observer.on(event)
    }

forwardOn函数中的_observer就是从订阅的时候Producer调用subscribe传过来的那个AnonymousObserver

四.总结

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值