美文网首页
RxJava2.X版本-create语法

RxJava2.X版本-create语法

作者: 河马过河 | 来源:发表于2018-08-08 10:51 被阅读29次

参考< https://www.jianshu.com/p/0cd258eecf60>

1、RxJava调用顺序

<1>Obserable创建

  public Observable<Integer> getRxJavaCreateExampleData() {
        return Observable.create(new ObservableOnSubscribe<Integer>() {
            @Override
            public void subscribe(ObservableEmitter<Integer> emitter) {
                LogUtils.debug(TAG, "getRxJavaCreateExampleData---:" + 1);
                emitter.onNext(1);

                LogUtils.debug(TAG, "getRxJavaCreateExampleData---:" + 2);
                emitter.onNext(2);

                LogUtils.debug(TAG, "getRxJavaCreateExampleData---:" + 3);
                emitter.onNext(3);
                emitter.onComplete();
                LogUtils.debug(TAG, "getRxJavaCreateExampleData---:" + 4);
                emitter.onNext(4);
            }
        });
    }

<2>Observer创建&订阅

  model.getRxJavaCreateExampleData()
                .subscribe(new Observer<Integer>() {
                    private Disposable disposable;

                    @Override
                    public void onSubscribe(Disposable d) {
                        disposable = d;
                        LogUtils.error(TAG, "rxJavaCreateExample---:onSubscribe");
                    }

                    @Override
                    public void onNext(Integer integer) {
                        LogUtils.error(TAG, "rxJavaCreateExample---:" + integer);
                    }

                    @Override
                    public void onError(Throwable e) {
                        LogUtils.error(TAG, "rxJavaCreateExample---:onError");
                    }

                    @Override
                    public void onComplete() {
                        LogUtils.error(TAG, "rxJavaCreateExample---:onComplete");

                    }
                });

调用日志

08-08 10:23:43.126 19790-19790/com.example.zhang E/MainPresenter: rxJavaCreateExample---:onSubscribe
08-08 10:23:43.126 19790-19790/com.example.zhang D/MainModel: getRxJavaCreateExampleData---:1
08-08 10:23:43.128 19790-19790/com.example.zhang E/MainPresenter: rxJavaCreateExample---:1
08-08 10:23:43.128 19790-19790/com.example.zhang D/MainModel: getRxJavaCreateExampleData---:2
08-08 10:23:43.129 19790-19790/com.example.zhang E/MainPresenter: rxJavaCreateExample---:2
08-08 10:23:43.129 19790-19790/com.example.zhang D/MainModel: getRxJavaCreateExampleData---:3
08-08 10:23:43.129 19790-19790/com.example.zhang E/MainPresenter: rxJavaCreateExample---:3
08-08 10:23:43.131 19790-19790/com.example.zhang E/MainPresenter: rxJavaCreateExample---:onComplete
08-08 10:23:43.132 19790-19790/com.example.zhang D/MainModel: getRxJavaCreateExampleData---:4

<3>添加线程调度

   model.getRxJavaCreateExampleData()
                .subscribeOn(Schedulers.io())
                .unsubscribeOn(Schedulers.io())
                .observeOn(AndroidSchedulers.mainThread())
                .subscribe(new Observer<Integer>() {
                    private Disposable disposable;

                    @Override
                    public void onSubscribe(Disposable d) {
                        disposable = d;
                        LogUtils.error(TAG, "rxJavaCreateExample---:onSubscribe");
                    }

                    @Override
                    public void onNext(Integer integer) {
                        LogUtils.error(TAG, "rxJavaCreateExample---:" + integer);
//                        if (integer == 2) {
//                            disposable.dispose();
//                        }
                    }

                    @Override
                    public void onError(Throwable e) {
                        LogUtils.error(TAG, "rxJavaCreateExample---:onError");
                    }

                    @Override
                    public void onComplete() {
                        LogUtils.error(TAG, "rxJavaCreateExample---:onComplete");

                    }
                });

调用日志

08-08 10:37:06.349 21365-21365/com.example.zhang E/MainPresenter: rxJavaCreateExample---:onSubscribe
08-08 10:37:06.354 21365-21827/com.example.zhang D/MainModel: getRxJavaCreateExampleData---:1
    getRxJavaCreateExampleData---:2
    getRxJavaCreateExampleData---:3
    getRxJavaCreateExampleData---:4
08-08 10:37:06.355 21365-21365/com.example.zhang E/MainPresenter: rxJavaCreateExample---:1
    rxJavaCreateExample---:2
    rxJavaCreateExample---:3
    rxJavaCreateExample---:onComplete

备注:测试Obserable 数据增加到1000 ,不再是Obserable把数据发送完,Obserer才开始。而是没有什么规律,这就是异步线程。

<4>Disposable中断

  model.getRxJavaCreateExampleData()
                .subscribeOn(Schedulers.io())
                .unsubscribeOn(Schedulers.io())
                .observeOn(AndroidSchedulers.mainThread())
                .subscribe(new Observer<Integer>() {
                    private Disposable disposable;

                    @Override
                    public void onSubscribe(Disposable d) {
                        disposable = d;
                        LogUtils.error(TAG, "rxJavaCreateExample---:onSubscribe");
                    }

                    @Override
                    public void onNext(Integer integer) {
                        LogUtils.error(TAG, "rxJavaCreateExample---:" + integer);
                        if (integer == 2) {
                            disposable.dispose();
                        }
                    }

                    @Override
                    public void onError(Throwable e) {
                        LogUtils.error(TAG, "rxJavaCreateExample---:onError");
                    }

                    @Override
                    public void onComplete() {
                        LogUtils.error(TAG, "rxJavaCreateExample---:onComplete");

                    }
                });

日志

08-08 10:49:10.831 23273-23273/com.example.zhang E/MainPresenter: rxJavaCreateExample---:onSubscribe
08-08 10:49:10.835 23273-23706/com.example.zhang D/MainModel: getRxJavaCreateExampleData---:1
    getRxJavaCreateExampleData---:2
    getRxJavaCreateExampleData---:3
    getRxJavaCreateExampleData---:4
08-08 10:49:10.837 23273-23273/com.example.zhang E/MainPresenter: rxJavaCreateExample---:1
    rxJavaCreateExample---:2

参考
https://www.jianshu.com/p/464fa025229e

河马过河微信公众号.jpg

相关文章

  • RxJava2.X版本-create语法

    参考< https://www.jianshu.com/p/0cd258eecf60> 1、RxJava调用顺序 ...

  • RxJava2.X版本-Concat语法

    一、Concat语法 日志 二、总结 1、发射器 B 把自己的数据按顺序送给了发射器 A,让他们组合成了一个新的发...

  • RxJava2.X版本-map语法

    一、map语法练习 1、Obserable创建 2、观察者-Consumer创建 3、日志 总结 1、map 基本...

  • RxJava2.X版本-zip语法

    一:zip语法练习 日志 总结 1、组合事件的过程就是分别从发射器 A 和发射器 B 各取出一个事件来组合,并且一...

  • Zookeeper常用命令详解

    使用的版本是Zookeeper3.6.1,不同版本会有一定的差异性。 新增命令 语法:create [-s] [-...

  • RxJava2.X版本-FlatMap和ConcatMap语法

    总结: 1、FlatMap 可以把一个发射器 Observable 通过某种方法转换为多个 Observable...

  • sqlite(2)-创建表

    语法## CREATE TABLE语句的基本语法如下: CREATE TABLE database_name.ta...

  • SQL语句之:DDL

    DDL语句 CREATE,ALTER,DROP CREATE 数据库操作 语法:CREATE {DATABASE ...

  • 创建MYSQL数据库

    使用CREATE DATABASE或CREATE SCHEMA命令可以创建数据库。 语法格式: CREATE DA...

  • 建立索引

    create index 名称 on 表名;create index i经营异常版本 on 经营异常(版本);

网友评论

      本文标题:RxJava2.X版本-create语法

      本文链接:https://www.haomeiwen.com/subject/azujvftx.html