zoukankan      html  css  js  c++  java
  • RxSwift学习笔记3:生命周期/订阅

    有了 Observable,我们还要使用 subscribe() 方法来订阅它,接收它发出的 Event。

            let observal = Observable.of("a","b","c")
            /*
             第一种用法:
             我们使用 subscribe() 订阅了一个 Observable 对象.
             该方法的 block 的回调参数就是被发出的 event 事件,我们将其直接打印出来。
             */
            let subscrioble =  observal.subscribe { (event) in
                print(event)
            }
            
            //一个 Observable 序列被创建出来后它不会马上就开始被激活从而发出 Event,而是要等到它被某个人订阅了才会激活它。
            //而 Observable 序列激活之后要一直等到它发出了 .error 或者 .completed 的 event 后,它才被终结。
            /*
             (1)使用该方法我们可以手动取消一个订阅行为。
             (2)如果我们觉得这个订阅结束了不再需要了,就可以调用 dispose() 方法把这个订阅给销毁掉,防止内存泄漏。
             (2)当一个订阅行为被 dispose 了,那么之后 observable 如果再发出 event,这个已经 dispose 的订阅就收不到消息了。
             */
            subscrioble.dispose()
            
            /*
             除了 dispose() 方法之外,我们更经常用到的是一个叫 DisposeBag 的对象来管理多个订阅行为的销毁:
             我们可以把一个 DisposeBag 对象看成一个垃圾袋,把用过的订阅行为都放进去。
             而这个 DisposeBag 就会在自己快要 dealloc 的时候,对它里面的所有订阅行为都调用 dispose() 方法。
             */
            let disposeBag = DisposeBag()
            /*
             第二种用法:
             通过不同的 block 回调处理不同类型的 event。
             同时会把 event 携带的数据直接解包出来作为参数,方便我们使用。
             */
            observal.subscribe(onNext: { (element) in
                print(element)
            }, onError:{ error in
                print(error.localizedDescription)
            }, onCompleted: {
                print("完成了")
            }, onDisposed: {
                print("销毁了")
            }).disposed(by: disposeBag)
            
            //subscribe() 方法的 onNext、onError、onCompleted 和 onDisposed 这四个回调 block 参数都是有默认值的,即它们都是可选的。所以我们也可以只处理 onNext 而不管其他的情况。
            observal.subscribe(onNext: { (element) in
                print(element)
            },onCompleted: {
                print("完成了")
            }).disposed(by: disposeBag)
            
            /*
             我们可以使用 doOn 方法来监听事件的生命周期,它会在每一次事件发送前被调用。
             同时它和 subscribe 一样,可以通过不同的 block 回调处理不同类型的 event
             do(onNext:) 方法就是在 subscribe(onNext:) 前调用
             */
            observal
                
                .do(onNext: { (element) in
                    print("++++监听下一个内容:", element)
                }, onError: { (error) in
                    print("++++监听错误", error)
                }, onCompleted: {
                    print("++++监听完成")
                }, onSubscribe: {
                    print("++++订阅监听")
                }, onSubscribed: {
                    print("++++已被订阅")
                }, onDispose: {
                    print("++++被销毁了")
                })
                
                .subscribe(onNext: { (element) in
                    print("++++订阅内容:",element)
                }, onError: { (error) in
                    print(error)
                }, onCompleted: {
                    print("++++订阅完成")
                }, onDisposed: {
                    print("++++订阅被销毁")
                }).disposed(by: disposeBag)
            /* ====>
             ++++订阅监听
             ++++已被订阅
             ++++监听下一个内容: a
             ++++订阅内容: a
             ++++监听下一个内容: b
             ++++订阅内容: b
             ++++监听下一个内容: c
             ++++订阅内容: c
             ++++监听完成
             ++++订阅完成
             ++++订阅被销毁
             ++++被销毁了
             */
    

      

  • 相关阅读:
    cogs 1272. [AHOI2009] 行星序列
    1027. 打印沙漏(20)
    1026. 程序运行时间(15)
    1023. 组个最小数 (20)
    《C语言程序设计(第四版)》阅读心得(四 文件操作)
    1022. D进制的A+B (20)
    1021. 个位数统计 (15)
    1020. 月饼 (25)
    1015. 德才论 (25)
    1009. 说反话 (20)
  • 原文地址:https://www.cnblogs.com/mapanguan/p/9237057.html
Copyright © 2011-2022 走看看