RxJava

RxJava

RxJava是啥?呵呵!?
关键是事件变换,线程调度,响应式编程
而怎么实现这些呢:最关键的就是接口泛型!
实现这些有什么用呢?

基本概念

Observable: 被观察者
OnSubscrible: 观察者
Operator: 观察者
Subscriber: 订阅者->其实也是一个观察者

首先我们要搞懂这三者之间的关系,
其实很简单
RxJava_第1张图片

Action: Call方法无返回值
Func: Call方法有返回值
RxJava_第2张图片

这是基本的对象概念。
这样子看其实也挺抽象的,怎样才能真正理解呢?
其实他们是有引入泛型的
然而+上泛型以后就复杂多了
接下来我们看看+上泛型的关系图
RxJava_第3张图片

具体化 举个栗子

上面说的太抽象了–>接下来具体化一下来深入理解这里的概念
Observable: 被观察者
抽象的
OnSubscrible: 观察者–>产品T
Operator< T, R> : 观察者–>项目组
Subscriber: 订阅者->其实也是一个观察者–>抽象的技术
Action–>void call(T t): 产品技能–>提需求
Func< T, R>–>R call(T t): 需求–>转化成–>功能
具体的
OnSubscribleImpl< T, R> implements OnSubscrible 技术的老大
MapSubscriber< T , R> 具体的技术

事件变换

接下来,咋们就看看事件变换是啥玩意!
其实也就是把< T >跟< R >做交换!
这么6!?
那么是怎样把他们做交换的呢?
这时候我们就可以通过
实现 OnSubscrible:Operator: 两个接口来实现!
当然这里面我们应该需要用到 Subscriber: 来帮助!

那么怎么搞法呢?!哈哈!

我们可以用心想想!
这里其实是比较难的,我就直接贴代码了!
怎么理解呢?
其实关键在于接口对象的使用。

/**
 * Project: ${file_name}
* Create Date: 2017/5/29
* Author: Tongson
* Description: ObservableDistinctUntilChanged OnSubscrible对象交换者 供subscrible(Subscriber subscriber)调用
* Description: 技术的老大-->分派任务
*/
public class OnSubscribleImpl<T, R> implements OnSubscrible<R> { /** * 产品 */ OnSubscrible onSubscrible; /** * 交换操纵者 -->需求换成-->具体的功能 * extends 返回类型的限定 * super 参数类型的限定 * T 需求 * R 功能 */ Operatorextends R, ? super T> operator; public OnSubscribleImpl(OnSubscrible onSubscrible, Operatorextends R, ? super T> operator) { this.onSubscrible = onSubscrible; this.operator = operator; } /** * 外部调用 * 让交换操纵者 返回Subscriber tSubscriber * 老大 让产品提需求给技术去做功能(分派任务) * * @param subscriber */ @Override public void call(Subscribersuper R> subscriber) { /** * operator 项目组 * tSubscriber 技术 */ Subscribersuper T> tSubscriber = operator.call(subscriber); /** * 老大 直接把产品分派给技术(分派任务) */ onSubscrible.call(tSubscriber); } }
/**
 * Project: ${file_name}
* Create Date: 2017/5/27
* Author: Tongson
* Description: 方法交换操纵者 项目组 具体的观察者-->具体的项目组
* 项目组 * T 需求 * R 功能 */
public class OperatorMap<T, R> implements Operator<R, T> { Funcsuper T, ? extends R> transformer; public OperatorMap(Funcsuper T, ? extends R> transformer) { this.transformer = transformer; } @Override public Subscribersuper T> call(Subscribersuper R> subscriber) { /** * 返回 Subscriber 对象 */ return new MapSubscriber<>(subscriber, transformer); } /** * 具体的技术 * * @param * @param */ private class MapSubscriber<T, R> extends Subscriber<T> { private Subscribersuper R> actual; private Funcsuper T, ? extends R> mapper; public MapSubscriber(Subscribersuper R> actual, Funcsuper T, ? extends R> mapper) { this.actual = actual; this.mapper = mapper; } @Override public void onNext(T t) { /** * Map中call方法的调用 */ R r = mapper.call(t); /** * Subscriber 对象中的方法的调用 技术-->做功能 */ actual.onNext(r); } } }

线程调度

然后我们就来看看
线程是怎样去控制的?!
其实也不是很难(比起上面的事件变换容易)

主要是通过继承OnSubscrible中也就是OnSubscrible的儿子提供的线程控制的方法
Schedulers

在call方法中我们用 Observable: subscrible()->调起订阅的时候在里面把这方法转成想要的线程就可以了!

                /**
                 * String  类型  代表需求
                 * Bitmap  代表 功能
                 * new OnSubscrible  产品
                 */
                Observable.create(new OnSubscrible() {
                    @Override
                    public void call(Subscribersuper String> subscriber) {
                        spannableStringBuilder.append("Observable -->Subscriber call:1" + "\n" + "currentThread:" + Thread.currentThread().getName() + "\n");

                        subscriber.onNext("http://www.baidu.com");
                        spannableStringBuilder.append("Observable -->Subscriber call:5" + "\n" + "currentThread:" + Thread.currentThread().getName() + "\n");
                        runOnUiThread(new Runnable() {
                            @Override
                            public void run() {
                                resultTv.setText(spannableStringBuilder);
                            }
                        });
                    }
                }).subscribleOnIO().map(new Func() {
                    //具体的转换类型角色
                    //老大让产品提需求给技术去做功能
                    @Override
                    public Bitmap call(String s) {
                        spannableStringBuilder.append("map-->OnSubscribleImpl call:" + "s:" + s + "\n");
                        spannableStringBuilder.append("currentThread:" + Thread.currentThread().getName() + "\n");
                        Bitmap bitmap = BitmapFactory.decodeResource(MainActivity.this.getResources(), R.mipmap.ic_launcher);
                        return bitmap;
                    }
                }).subscrible(new Subscriber() {
                    @Override
                    public void onNext(Bitmap bitmap) {
                        spannableStringBuilder.append("Subscriber onNext -->" + "\n" + "currentThread:" + Thread.currentThread().getName() + "\n");
                    }
                });

RxJava_第4张图片

被观察者 Observable

/**
 * Project: ${file_name}
* Create Date: 2017/5/27
* Author: Tongson
* Description: 被观察者
*/
public class Observable<T> { /** * 接口 回调 */ private OnSubscrible onSubscrible; /** * 构造器 * * @param onSubscrible */ private Observable(OnSubscrible onSubscrible) { this.onSubscrible = onSubscrible; } /** * 开始 * * @param onSubscrible * @param * @return */ public static Observable create(OnSubscrible onSubscrible) { return new Observable<>(onSubscrible); } /** * 订阅 * * @param subscriber */ public void subscrible(Subscribersuper T> subscriber) { onSubscrible.call(subscriber); } /** * 实例化 项目组 * 实例化 交换者 * * @param func * @param * @return */ public Observable map(Funcsuper T, ? extends R> func) { return lift(new OperatorMap<>(func)); } /** * 实例化 老大 * 实例化 对象交换者 * * @param trOperatorMap * @param * @return */ public Observable lift(OperatorMap trOperatorMap) { return new Observable<>(new OnSubscribleImpl<>(onSubscrible, trOperatorMap)); } public Observable subscribleOnIO() { return create(new OnSubscribleOnIO(this)); } public Observable subscribleMain() { return create(new OnSubscrbleMain(new Handler(Looper.getMainLooper()), this)); } }

这个被观察者贯穿所有的存在!

首先

create

订阅

subscrible
map
lift

线程

subscribleOnIO
subscribleMain

return

Observable
这里的方法都是返回Observable为了可以继续调用下去吧

响应式编程

                /**
                 * 响应式编程
                 */
                spannableStringBuilder.append("btn_2-------------------\n");
                Observable.create(new OnSubscrible() {
                    @Override
                    public void call(Subscribersuper String> subscriber) {
                        spannableStringBuilder.append("Observable -->Subscriber call:1" + "\n" + "currentThread:" + Thread.currentThread().getName() + "\n");
                        subscriber.onNext("http://www.baidu.com");
                        spannableStringBuilder.append("Observable -->Subscriber call:5" + "\n" + "currentThread:" + Thread.currentThread().getName() + "\n");
                    }
                }).map(new Func() {
                    //具体的转换类型角色
                    @Override
                    public Bitmap call(String s) {
                        spannableStringBuilder.append("map-->OnSubscribleImpl call:" + "s:" + s + "\n");
                        spannableStringBuilder.append("currentThread:" + Thread.currentThread().getName() + "\n");
                        Bitmap bitmap = BitmapFactory.decodeResource(MainActivity.this.getResources(), R.mipmap.ic_launcher);
                        return bitmap;
                    }
                }).subscrible(new Subscriber() {
                    @Override
                    public void onNext(Bitmap bitmap) {
                        spannableStringBuilder.append("Subscriber onNext -->" + "\n" + "currentThread:" + Thread.currentThread().getName() + "\n");
                    }
                });
                spannableStringBuilder.append("btn_2-------------------\n\n");
                resultTv.setText(spannableStringBuilder);

RxJava_第5张图片

手写RxJavaDemo

https://github.com/gepriniusce/TongsonPlay/tree/rxjava

RxJava2用法Demo

https://github.com/amitshekhariitbhu/RxJava2-Android-Samples

RxJava的思想很值得学习
而RxJava框架也是很好,对于复杂逻辑的代码我们可以直接用Rx这样子就算换一个同事来看这代码也比较清晰。

你可能感兴趣的:(Android框架)