RxJavaAndroid学习笔记

当子线程处理某个逻辑要在主线程显示的时候使用。


   Observable.just(currentBytesCount).observeOn(AndroidSchedulers.mainThread()).subscribe(new Action1<Long>() {

                                    @Override
                                    public void call(Long aLong) {
                                        tvMsg.setText("提示:上传中");
                                        progressBar.setMax((int) totalBytesCount);
                                        progressBar.setProgress((int) currentBytesCount);
                                    }
                                });

清神咒

! 我感觉吧,也许Rx之所以让人感觉恐惧学习成本高,是因为被一些术语绕来绕去绕晕了,术语太抽象,不接近生活本质、很难理解,或者记忆深刻,什么发射,什么观察者、被观察者、什么onNext,但是我一直被这些文章吓得不轻,也被这单词绕来绕去绕晕了,产生了恐惧中,什么观察啊被观察头都晕了,现在我撸了屡,通熟易懂的来说 来本质无非就是 添加一个回调到一个操作类里面,执行这个操作类的时候的时候会遍历调用这些回调, 只是执行的时候可以设置在主线程回调还是子线程回调 以及自己的任务是在主线程执行还是子线程执行
2、没有学以致用,或者不知道什么时候用,应该把什么东西改成什么。

单词介绍和转换概念加深印象

这里不得不说一个事情,就是记忆的技巧,如果你觉得一个东西太过抽象,但是要想不对他产生恐惧,而且想轻松记下来,不会搞混淆搞反,你应该把它变成你熟悉的业务,这样方便你一气呵成,而不是扭啊扭的被术语绕晕。

观察者Observer

1、把它理解操作类
2、把它业务逻辑类
3、强加一个印象,他音乐播放器的具体实现类代码类
4、管理这些回调/处理的逻辑回调的类
5、发布事件的 ,上游

被观察者Observable

1、把它理解为一个回调
2、把它理解为业务逻辑最终执行的你想知道的一个方法活多个监听接口
3、把它理解为一个音乐播放器的进度播放回调、暂停回调。
4、 下游、一般用于主线程
5、接受时间的

订阅 Subscribe

就是把Observer添加到Observable中持有,这样有点饶了,那么换通熟易懂一点。
1、把回调添加到这个控制器的回调接口列表,它会在适当的时机回调它。
2、给就是音乐播放器的控制类设置一个回调、可以设置一个或者多个。
示例

import java.util.Arrays;

import io.reactivex.Flowable;
import io.reactivex.Observable;
import io.reactivex.ObservableEmitter;
import io.reactivex.ObservableOnSubscribe;
import io.reactivex.ObservableOperator;
import io.reactivex.ObservableSource;
import io.reactivex.Observer;
import io.reactivex.disposables.Disposable;
import io.reactivex.functions.Action;
import io.reactivex.functions.Consumer;
import io.reactivex.functions.Function;
import io.reactivex.schedulers.Schedulers;

/**
 * Created by qssq on 2018/11/14 qssq666@foxmail.com
 */

public class Main {

    public static void print(String str) {
        System.out.println("Main.print:" + str);
    }

    public void print_obj(String str) {
        System.out.println("Main.print_obj:" + str);
    }


    public static void main(String[] args) {
        System.out.println("hllll");
//        testObservableSimple();

     /*   Observable.fromArray(new byte[]{11111})
                .flatMap((Func1) (folder) -> {
                    Observable.from(file.listFiles())
                })
                .filter((Func1) (file) -> {
                    file.getName().endsWith(".png")
                })
                .map((Func1) (file) -> {
                    getBitmapFromFile(file)
                })
                .subscribeOn(Schedulers.io())
                .observeOn(AndroidSchedulers.mainThread())
                .subscribe((Action1) (bitmap) -> {
                    imageCollectorView.addImage(bitmap)
                });*/
//        testObservable1();

  /*      Subscriber<Course> subscriber = new Subscriber<Course>() {
            @Override
            public void onSubscribe(Subscription s) {

            }

            @Override
            public void onNext(Course course) {
            }

            @Override
            public void onError(Throwable t) {

            }

            @Override
            public void onComplete() {

            }
        };*/


//        testOneObjectMultiChild();
//        testLift();
//        testSmiple();


        try {

            Thread.sleep(8000);

        } catch (Exception e) {

        }


    }

    private static void testLift() {//据说也属于变黄。
        Observable.just(1, 2, 3, 50, 60)//打印 1 2 3 4,
                .lift(new ObservableOperator<String, Integer>() { //lift 举起 鼓舞 如果没有使用list,那么 这interger 最后接受的也只能是int,而用这个就实现了变换。  泛型 左边 为 要转换的类型,右边则表示之前的类型 这里必须写成integer,因为之前fajust返回的以及是integer了。

                    @Override
                    public Observer<? super Integer> apply(Observer<? super String> observer) throws Exception {
                        return new Observer<Integer>() {
                            @Override
                            public void onSubscribe(Disposable d) {
                                observer.onSubscribe(d);
                            }

                            @Override
                            public void onNext(Integer integer) {

                                observer.onNext("数字10" + integer + "的16进制为;" + Integer.toHexString(integer));
                            }

                            @Override
                            public void onError(Throwable e) {

                                observer.onError(e);
                            }

                            @Override
                            public void onComplete() {

                                observer.onComplete();
                            }
                        };
                    }
                })
                .subscribeOn(Schedulers.io()) // 指定 subscribe() 发生在 IO 线程 导致不打印
                .observeOn(Schedulers.newThread()) // 指定 Subscriber 的回调发生在主线程
                .subscribe(new Consumer<String>() {
                    @Override
                    public void accept(String o) throws Exception {
                        System.out.println("lift结果:" + o);
                    }
                });
    }

    private static void testOneObjectMultiChild() {
        //遍历 一对多  所有学生的所学的课程 ,默认是 英语  数学, 张三除外。一对多关系。   map和 flatMap的区别。
        Student[] students = new Student[]{Student.newInstance("张三").setCourses(new Course[]{Course.newInstance("德语"), Course.newInstance("日语")}), Student.newInstance("李四"), Student.newInstance("王老五"), Student.newInstance("某某")};


        Observable.fromArray(students)
                .flatMap(new Function<Student, ObservableSource<Course>>() {
                    @Override
                    public ObservableSource<Course> apply(Student student) throws Exception {
                        return Observable.fromArray(student.getCourses());//flatMap是1对多, 而map只能1对1 返回。
                    }
                })
                .subscribe(new Consumer<Course>() {
                    @Override
                    public void accept(Course course) throws Exception {
                        System.out.println("课程:" + course.getName());
                    }
                });
    }

    public static class Course {
        public String getName() {
            return name;
        }

        public Course(String name) {
            this.name = name;
        }

        public Course() {
        }

        public void setName(String name) {
            this.name = name;
        }

        public static Course newInstance(String name) {
            return new Course(name);
        }

        String name;
    }

    public static class Student {
        private Course[] courses = new Course[]{Course.newInstance("英语"), Course.newInstance("数学")};

        public String getName() {
            return name;
        }

        public Student() {
        }

        private String name;

        public Student(String name) {
            this.name = name;
        }

        public static Student newInstance(String name) {
            return new Student(name);
        }

        public static Student newInstance(String name, Course[] courses) {
            return new Student(name).setCourses(courses);
        }

        public Student setCourses(Course[] courses) {
            this.courses = courses;
            return this;
        }

        public Course[] getCourses() {

            return courses;
        }

    }

    private static void testSmiple() {
        Flowable.just("Hello world").subscribe(System.out::println);//表示调用System.out.println来接受字符串 ()
        Flowable.just("Hello world").subscribe(new Main()::print_obj);//自己定义的方法 非静态
        Flowable.just("Hello world").subscribe(Main::print);//自己定义的方法,为静态
        Flowable.just("Hello world").subscribe(new Consumer<String>() {//这种写法等价。
            @Override
            public void accept(String s) throws Exception {
                System.out.println("" + s);
            }
        });


        Flowable.just("Hello world").subscribe(new Consumer<String>() {
            @Override
            public void accept(String s) throws Exception {
                System.out.println("" + s);
            }
        });
/*
        Flowable.fromCallable(new Callable<Object>() {
            @Override
            public Object call() throws Exception {
                return null;
            }
        });*/
        //lamba  貌似度一样的执行,模拟背压了??


        Flowable.fromCallable(() -> {
            Thread.sleep(5320); //  imitate expensive computation 模拟耗时 昂贵的计算。
            return "耗时不啊 ,啊啊啊啊啊啊";
        })
                .subscribeOn(Schedulers.io())
                .observeOn(Schedulers.single())
                .subscribe(System.out::println, Throwable::printStackTrace);

        //范围打印 也可以实现,学生一对多?
        Flowable.range(1, 10)
                .parallel()//自动推导 int
                .runOn(Schedulers.computation())
                .map(v -> v * v)
                .sequential()//顺序执行
                .blockingSubscribe(System.out::println);

//            Flowable.


        //遍历数组。
        String[] names = new String[]{"333", "555", "6666"};
        Observable.fromArray(names)
                .subscribe(new Consumer<String>() {//消费者,也就是 观察者
                    @Override
                    public void accept(String s) throws Exception {
                        System.out.println(" arr:" + s);
                    }
                });
        //有问题,不能指定 订阅线程, 是因为过早退出了
        Observable.just(1, 2, 3, 4)
                .subscribeOn(Schedulers.io()) // 指定 subscribe() 发生在 IO 线程 导致不打印
                .observeOn(Schedulers.newThread()) // 指定 Subscriber 的回调发生在主线程
                .subscribe(new Consumer<Integer>() {
                    @Override
                    public void accept(Integer integer) throws Exception {
                        System.out.println("," + integer);
                    }
                });
    }

    private static void testObservableSimple() {
        Observable.create(new ObservableOnSubscribe<StringBuffer>() {//这里的泛型代表开始发布的泛型。
            @Override
            public void subscribe(ObservableEmitter<StringBuffer> emitter) throws Exception {
                //
                System.out.println("1、有人订阅了,我要发布," + "," + Thread.currentThread().getName());
                emitter.onNext(new StringBuffer("很好爱爱"));
                emitter.onComplete(); // 如果调用了,这个,那么下面的方法都不会继续调用了, 这个应该放到最后面,另外不调用的话也不影响逻辑正常执行,只是不会回调onComplete
//                emitter.onError(new Throwable("测试异常onError"));
            }
        }).map(new Function<StringBuffer, StringBuffer>() {
            @Override
            public StringBuffer apply(StringBuffer stringBuffer) throws Exception {
                System.out.println("1.1、AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA,收到" + stringBuffer + "," + Thread.currentThread().getName());
                return new StringBuffer("map---------->");
            }
        })
                .subscribeOn(Schedulers.newThread())//不能插入这个,否则不会走 ,1.2.3
                .observeOn(Schedulers.newThread())//监听着执行在什么线程
                .subscribe(new Consumer<StringBuffer>() {
                    @Override
                    public void accept(StringBuffer stringBuffer) throws Exception {
                        System.out.println("2、处理结果:收到字符串:" + stringBuffer + "," + Thread.currentThread().getName());
                    }
                }, new Consumer<Throwable>() {
                    @Override
                    public void accept(Throwable throwable) throws Exception {
                        System.err.println("2、处理结果:收到异常:" + throwable + "," + Thread.currentThread().getName());
                    }
                }, new Action() {
                    @Override
                    public void run() throws Exception {
                        System.out.println("3、收到onCompletion:" + "," + Thread.currentThread().getName());

                    }
                });
    }

    private static void testObservable1() {
        //执行完毕自动执行 作用是从1-4 不断地发布,总共发布2次,都会走1 ,2 ,3, 4
        Observable.create(new ObservableOnSubscribe<String>() {
            @Override
            public void subscribe(ObservableEmitter<String> e) throws Exception {
                System.out.println("subscribe 方法调用,我发布一个时间 onNext 传递 你好 " + e + "," + Thread.currentThread().getName());
                e.onNext("你好"); //发送事件
                System.out.println("subscribe 方法调用,我继续发布一个时间 onNext 传递 你好 " + e + "," + Thread.currentThread().getName());
                e.onNext("你到底好不好"); //发送事件
//                e.onComplete();//某些文章说要调用,感觉没作用
//                e.onComplete();
//                e.onComplete();
                System.out.println("subscribe 任务下发完毕");
            }
        }).map(new Function<String, byte[]>() { // 左边为接受的参数,右边为返回值
            @Override
            public byte[] apply(String str) throws Exception {
                System.out.println("1、apply 收到字符串" + str + ",我返回结果数组:  " + str + "," + Thread.currentThread().getName());
                return new byte[]{};
            }
        }).map(new Function<byte[], String>() { // 输入字节码数组,保存文件,输出文件路径


            @Override
            public String apply(byte[] byteArray) throws Exception {

                System.out.println("2、apply arr 收到刚刚传递的数组 " + Arrays.toString(byteArray) + "我再次返回字符串: 哈哈哈 " + Thread.currentThread().getName());
                return "哈哈哈哈";
            }
        }).map(new Function<String, Integer>() { //输入class路径,jar uvf命令替换jar
            @Override
            public Integer apply(String s) throws Exception {
                System.out.println("3、apply  收到字符串" + s + "iinteger 我返回结果标记为1 " + Thread.currentThread().getName());
               /* if (s != "a") {
                    throw new RuntimeException("走 错误标记吧少年..");
                }*/
                return 1;
            }
        }).map(new Function<Integer, Float>() {

            @Override
            public Float apply(Integer integer) {
                System.out.println("3.1、apply  收到int " + integer + " iinteger 我返回结果标记为 5 " + Thread.currentThread().getName());
                return 5.0f;//如果这里第二个泛型 为float,那么 订阅 也应该是泛型。
            }
        }).subscribe(new Consumer<Float>() {//这里是订阅,订阅有一个成功和失败的回调。链式编程看习惯了就好了 e subscribe(Consumer<? super T> onNext, Consumer<? super Throwable> onError)
            @Override
            public void accept(Float status) throws Exception {//表示一个onNext onMap 等执行完毕但是
                System.out.println("4、result:accept  收到int值:" + status + "," + Thread.currentThread().getName());
            }
        }, new Consumer<Throwable>() {//表示的是上下发布了错误或者 抛出了错误。
            @Override
            public void accept(Throwable throwable) throws Exception {

                System.err.println("4、accept error:" + throwable.toString() + " ," + Thread.currentThread().getName());
            }
        });


    }

}

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

推荐阅读更多精彩内容

  • Swift1> Swift和OC的区别1.1> Swift没有地址/指针的概念1.2> 泛型1.3> 类型严谨 对...
    cosWriter阅读 11,094评论 1 32
  • 参考:给 Android 开发者的 RxJava 详解-扔物线深入浅出RxJava 基础 "a library f...
    Vincen1024阅读 542评论 0 1
  • 转一篇文章 原地址:http://gank.io/post/560e15be2dca930e00da1083 前言...
    jack_hong阅读 911评论 0 2
  • 在正文开始之前的最后,放上GitHub链接和引入依赖的gradle代码: Github: https://gith...
    苏苏说zz阅读 677评论 0 2
  • 1.产品介绍 1.1体验环境 产品名称:FitTime 版本号:3.1.0 体验设备:IponeSE 体验环境: ...
    Medoraa阅读 727评论 2 0