RxJava使用笔记

功能

关于RxJava的功能,虽说是简化了观察者模式的使用,但是看了网上大家的几个版本的demo,开始还感觉有些疑惑,后来意识到,Rxjava的目的在于简化代码,尤其是引入lamda函数式写法后,更可见一斑。
基于这个目的,也解释了我下面的一个疑惑

  • 问:为什么在Observable的subscribe里多次调用onNext?(见下面的代码示例)
  • 答: 其实这是示例代码给初接触者带来的歧义。subscribe真实的意图是,在里面顺序的dosomework1, dosomework2,onNext来反馈状态。不要将Emiter引用到subscribe外面来反馈状态不要在subscribe函数体外面处理事务, 理解了这两点,下面的一个问题就好回答了。
  • 问: 为什么不给observer和observerable定义局部变量来保存,然后重复利用对象体,而不用每次创建?
  • 答: java等高级语言的诞生,首先不是为了简化代码,而是为了更好的呈现流程。即:代码执行效率不是第一考虑因素,代码、框架的可读性才是首要追求。因此 Rxjava在设计之初就不是考虑对象复用,而是使用链式编程理念,尽量简化代码。于是每有一个新的任务,那就创建一各observer和observable去完成就是了,反正它们的代码也比较简洁(虽然最终的.dex文件里的转码不是)。
new ObservableOnSubscribe<String>() {
            @Override
            public void subscribe(ObservableEmitter<String> observableEmitter) throws Exception {
                ALog.i("process and report result");
                observableEmitter.onNext("processing1");
                observableEmitter.onNext("processing2");
                observableEmitter.onComplete();
            }
        }
简单使用

因为考虑到代码简洁性,所以沿用链式编程,一个sample如下:

Observable.create((ObservableOnSubscribe<String>) observableEmitter -> {
            ALog.i("process and report result");
            observableEmitter.onNext("processing");
            observableEmitter.onComplete();
        }).subscribe(new Observer<String>() {

            @Override
            public void onSubscribe(Disposable disposable) {

            }

            @Override
            public void onNext(String s) {
                ALog.i("observer received:" + s);
            }

            @Override
            public void onError(Throwable throwable) {

            }

            @Override
            public void onComplete() {
                ALog.i("observer received complete");
            }
        });

但是这段代码看上去还是比较臃肿,进一步简化如下:

        Observable.just("reading").subscribe(s -> { 
            // show reading in UI thread
            ALog.i("observer accept " + s); 
        });

Observable.just跟Observable.create的效果是一样的,创建一个observable。昨天我还有点不太明白,Observable的subscribe回调函数都省了?我在哪通知呢?
Observable.just的意图很明了,就是在你调用的那个地方的事情处理完了后,直接用Observable.just将状态上报给observer。subscribe函数是多余的,subscribe等价于Observable.just被调的地方所在的函数。

Observable.just有多个参数的使用场合?

看介绍Observable.just可以依次上报多个参数(每个参数的上报等价于使用代码拷贝了一份,虽然隐含的代码量增加了,但是我们的source code还是比较简洁的,所以java考虑的不是效率,而是代码的可读性和功能的独立性,高内聚、低耦合...)
Observable.just使用多参数上报,其实可以简单的考虑为将事务、状态分解,让observer的回调函数一次处理一种状态,而不是 一次顺序的处理多个事务、状态的上报。例如下面的例子:

Observable.just("get up", "eat", "sleep").subscribe(s -> {
            if (s.equals("get up")) {
                ALog.i("observer accept [thread: " + Thread.currentThread().getName()+ "] display get up");
            } else if (s.equals("eat")) {
                ALog.i("observer accept [thread: " + Thread.currentThread().getName()+ "] display eat");
            } else if (s.equals("sleep")) {
                ALog.i("observer accept [thread: " + Thread.currentThread().getName()+ "] display sleep");
            }
        });

执行结果如下, subscribe的回调,调用了三次:

[Info]:observer accept [thread: main] display get up
[Info]:observer accept [thread: main] display eat
[Info]:observer accept [thread: main] display sleep

可以简单的理解为:代码的caller是被监听的线程,事务完成后,需要将状态转达给监听者,即用RxJava这个调用方式即可。

map的使用

假如有数据列表需要转换数据后再上报,则可以采用map转换操作符。Action0 改名成Action,Action1改名成Consumer,而Action2改名成了BiConsumer,而Action3 - Action9都不再使用了,ActionN变成了Consumer<Object[]>。
代码如下

Observable.just(1, 2, 3, 4, 5)
                .map(integer -> {
                    ALog.i("[thread: " + Thread.currentThread().getName()+ "] " + "worker report " + integer);
                    return "This is " + integer;
                })
                .subscribeOn(Schedulers.io())
                .observeOn(Schedulers.newThread())
                .subscribe(s -> ALog.i("[thread: " + Thread.currentThread().getName()+ "] " + "observer accept " + s));

代码执行情况如下, observer的回调在线程RxNewThreadScheduler-1, 工作者的上报在RxCachedThreadScheduler-1线程。

[Info]:[thread: RxCachedThreadScheduler-1] worker report 1
[Info]:[thread: RxCachedThreadScheduler-1] worker report 2
[Info]:[thread: RxNewThreadScheduler-1] observer accept This is 1
[Info]:[thread: RxNewThreadScheduler-1] observer accept This is 2
[Info]:[thread: RxCachedThreadScheduler-1] worker report 3
[Info]:[thread: RxCachedThreadScheduler-1] worker report 4
[Info]:[thread: RxCachedThreadScheduler-1] worker report 5
[Info]:[thread: RxNewThreadScheduler-1] observer accept This is 3
[Info]:[thread: RxNewThreadScheduler-1] observer accept This is 4
[Info]:[thread: RxNewThreadScheduler-1] observer accept This is 5
flatMap的用途与map类似,它是将一组数据对象分别提取,然后再提取每个对象里的子项目,相当于for循环创建了observer和observable
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,014评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,796评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,484评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,830评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,946评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,114评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,182评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,927评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,369评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,678评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,832评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,533评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,166评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,885评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,128评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,659评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,738评论 2 351