RxJava 和 RxAndroid 一 (基础)

1、RxJava 项目地址

   https://github.com/ReactiveX/RxJava

 

2、RxAndroid 项目地址

   https://github.com/ReactiveX/RxAndroid

 

3、RxJava 和 RxAndroid 的关系

     RxAndroid是RxJava的一个针对Android平台的扩展,主要用于 Android 开发

 

4、RxJava和EventBus的区别?

     https://www.zhihu.com/question/32179258/answer/54989242

 

5、RxAndroid的使用方法

    compile 'io.reactivex:rxandroid:1.2.0'

   

6、如何查看RxAndroid最新版本?

    http://search.maven.org/#search%7Cga%7C1%7Ca%3A%22rxandroid%22

 

 7、RxAndroid具体使用方法

     http://gank.io/post/560e15be2dca930e00da1083#toc_14

     http://blog.csdn.net/theone10211024/article/details/50435325

    http://huxian99.github.io/tags/RxJava/

    https://github.com/mcxiaoke/RxDocs

 

 8、创建观察者

package lib.com.myapplication;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;

import rx.Observer;
import rx.Subscriber;

public class Main2Activity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main2);

        //创建观察者 2 种方法
        Observer<String> observer = new Observer<String>() {
            @Override
            public void onCompleted() {

            }

            @Override
            public void onError(Throwable e) {

            }

            @Override
            public void onNext(String s) {

            }
        } ;

        // Subscriber 继承 Observer ,对Observer类做了扩展
        Subscriber<String> subscriber = new Subscriber<String>() {
            @Override
            public void onCompleted() {

            }

            @Override
            public void onError(Throwable e) {

            }

            @Override
            public void onNext(String s) {

            }

        } ;

    }
}
  • 从上文可以看到,Subscriber继承Observer, 只是 Subscriber对Observer做了一些扩展。Subscriber的使用和Observer完全一样。
  •  Subscriber 多了一个 onStart 方法
  • onStart(): 这是 Subscriber 增加的方法。它会在 subscribe 刚开始,而事件还未发送之前被调用,可以用于做一些准备工作,例如数据的清零或重置。这是一个可选方法,默认情况下它的实现为空。需要注意的是,如果对准备工作的线程有要求(例如弹出一个显示进度的对话框,这必须在主线程执行), onStart() 就不适用了,因为它总是在 subscribe 所发生的线程被调用,而不能指定线程。要在指定的线程来做准备工作,可以使用 doOnSubscribe() 方法,具体可以在后面的文中看到。
 // Subscriber 继承 Observer ,对Observer类做了扩展
        Subscriber<String> subscriber = new Subscriber<String>() {
            @Override
            public void onCompleted() {

            }

            @Override
            public void onError(Throwable e) {

            }

            @Override
            public void onNext(String s) {

            }

            @Override
            public void onStart() {
                super.onStart();
            }
        } ;

  

9、创建被观察者

       //create方式
        Observable<String> observable = Observable.create(new Observable.OnSubscribe<String>() {
            @Override
            public void call(Subscriber<? super String> subscriber) {
                subscriber.onNext( "aa" ) ;
                subscriber.onNext( "bb" ) ;
                subscriber.onNext( "cc" ) ;
                subscriber.onCompleted();
            }
        });

        //just方式  最多支持10个数据
        Observable<String> observable1 = Observable.just( "aa" , "bb" , "cc") ;
        // 将会依次调用:
        // onNext("aa");
        // onNext("bb");
        // onNext("cc");
        // onCompleted();

        //from方式
        //1:集合
        List<String> list = new ArrayList<>() ;
        list.add( "aa" ) ;
        list.add( "bb" ) ;
        list.add( "cc" ) ;

        Observable<String> observable2 = Observable.from( list ) ;

        //2:数组
        String[] words = { "aa", "bb", "cc" };
        Observable<String> observable3 = Observable.from( words ) ;
  • Call()方法:当 Observable 被订阅的时候,OnSubscribe 的 call() 方法会自动被调用,事件序列就会依照设定依次触发(对于上面的代码,就是观察者Subscriber 将会被调用三次 onNext() 和一次 onCompleted())。这样,由被观察者调用了观察者的回调方法,就实现了由被观察者向观察者的事件传递,即观察者模式。

  

 10、订阅

      由于观察者可以由两种方式被创建,所以订阅的方式也有两种

        observable.subscribe( observer ) ;
        observable.subscribe( subscriber ) ;
  • Observable.subscribe(Subscriber) 的内部实现是这样的(仅核心代码):

            // 注意:这不是 subscribe() 的源码,而是将源码中与性能、兼容性、扩展性有关的代码剔除后的核心代码。
            // 如果需要看源码,可以去 RxJava 的 GitHub 仓库下载。
            public Subscription subscribe(Subscriber subscriber) {
                subscriber.onStart();
                onSubscribe.call(subscriber);
                return subscriber;
            }
  1. 在subscribe() 中,首先会调用 onStart() 方法,这个方法前文已经介绍了,是可选的。接着会调用 call()方法,我们已经分析了在call()方法中会调用多次 onNext() ,最后调用 onCompleted().看到这里你就会突然明白原来subscribe() 方法其实相当于依次执行了:onStart() --> onNext()--> onCompleted()
  2. 从这也可以看出,在 RxJava 中,Observable 并不是在创建的时候就立即开始发送事件,而是在它被订阅的时候,即当 subscribe() 方法执行的时候。
  3. Observer 和 Subscriber 具有相同的角色,而且 Observer 在 subscribe() 过程中最终会被转换成 Subscriber对象
  4. 将传入的 Subscriber 作为 Subscription 返回。这是为了方便 unsubscribe().   

 

 11、RxBus

         你是否听说过EventBus , 他是android 中的事件总线。用rxjava同样可以实现android的事件总线功能,也就是RxBus.

        关于rxbus 的基本说明在这里 http://nerds.weddingpartyapp.com/tech/2014/12/24/implementing-an-event-bus-with-rxjava-rxbus/

        然而这并没有什么卵用 !

         下面是RxBus的封装版        

package lib.com.myapplication;
import android.support.annotation.NonNull;
import android.util.Log;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
import java.util.concurrent.ConcurrentHashMap;
import rx.Observable;
import rx.subjects.PublishSubject;
import rx.subjects.Subject;

/**
 * Created by ${zyj} on 2016/5/6.
 */
public class RxBus {

    private static final String TAG = RxBus.class.getSimpleName();
    private static RxBus instance;
    public static boolean DEBUG = false;

    public static RxBus get() {
        if (instance == null) {
            synchronized (RxBus.class) {
                if (instance == null) {
                    instance = new RxBus();
                }
            }
        }
        return instance;
    }

    private RxBus() {
    }

    private ConcurrentHashMap<Object, List<Subject>> subjectMapper = new ConcurrentHashMap<>();

    @SuppressWarnings("unchecked")
    public <T> Observable<T> register(@NonNull Object tag, @NonNull Class<T> clazz) {
        List<Subject> subjectList = subjectMapper.get(tag);
        if (null == subjectList) {
            subjectList = new ArrayList<>();
            subjectMapper.put(tag, subjectList);
        }

        Subject<T, T> subject;
        subjectList.add(subject = PublishSubject.create());
        if (DEBUG) Log.d(TAG, "[register]subjectMapper: " + subjectMapper);
        return subject;
    }

    public void unregister(@NonNull Object tag, @NonNull Observable observable) {
        List<Subject> subjects = subjectMapper.get(tag);
        if (null != subjects) {
            if ( observable != null  && subjects.contains( observable )){
                subjects.remove((Subject) observable);
            }

            if (isEmpty(subjects)) {
                subjectMapper.remove(tag);
            }
        }

        if (DEBUG) Log.d(TAG, "[unregister]subjectMapper: " + subjectMapper);
    }

    public void post(@NonNull Object content) {
        post( content.getClass().getName(), content);
    }

    @SuppressWarnings("unchecked")
    public void post(@NonNull Object tag, @NonNull Object content) {
        List<Subject> subjectList = subjectMapper.get(tag);

        if (!isEmpty(subjectList)) {
            for (Subject subject : subjectList) {
                subject.onNext(content);
            }
        }
        if (DEBUG) Log.d(TAG, "[send]subjectMapper: " + subjectMapper);
    }

    private boolean isEmpty(Collection collection) {
        return null == collection || collection.isEmpty();
    }
}

  RxBus的使用

package lib.com.myapplication;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import rx.Observable;
import rx.functions.Action1;

public class Activity1 extends AppCompatActivity {

    String tag = "tag" ;
    Observable<String> ob ;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity1);

        //创建被观察者
        ob = RxBus.get().register( tag , String.class ) ;
        //订阅观察事件
        ob.subscribe(new Action1<String>() {
            @Override
            public void call(String s) {
                System.out.println( "fff-- " + s  );
            }
        }) ;

        //发送内容
        RxBus.get().post(  tag , "我是内容" );
    }

    @Override
    protected void onDestroy() {
        super.onDestroy();
        //取消订阅
        RxBus.get().unregister( tag , ob );
    }
}
  • 在Activity销毁的时候,要取消订阅服务 。 否则 post() 次数会随着post()调用逐渐增加
  • 除了上面的简单使用外,还可以使用  SchedulersAndroidSchedulers 进行线程切换

      

RxJava 和 RxAndroid 二(操作符的使用)

时间: 2024-09-26 09:46:05

RxJava 和 RxAndroid 一 (基础)的相关文章

RxJava 和 RxAndroid 二(操作符的使用)

前言:对Rx不了解的朋友可以先看我的第一篇博文 RxJava 和 RxAndroid 一 (基础),是对Rxjava的基本介绍   1.merge操作符,合并观察对象 19 List<String> list1 = new ArrayList<>() ; 20 List<String> list2 = new ArrayList<>() ; 21 22 list1.add( "1" ) ; 23 list1.add( "2&qu

RxJava 和 RxAndroid 五(线程调度)

对rxJava不了解的同学可以先看 RxJava 和 RxAndroid 一 (基础)RxJava 和 RxAndroid 二(操作符的使用)RxJava 和 RxAndroid 三(生命周期控制和内存优化) RxJava 和 RxAndroid 四(RxBinding的使用)   本文将有几个例子说明,rxjava线程调度的正确使用姿势. 例1 Observable .create(new Observable.OnSubscribe<String>() { @Override public

RxJava 和 RxAndroid 三(生命周期控制和内存优化)

rxjava rxandroid 赵彦军 前言:对Rxjava.Rxandroid不了解的同学可以先看看RxJava 和 RxAndroidRxJava 和 RxAndroid 二(操作符的使用) RxJava使我们很方便的使用链式编程,代码看起来既简洁又优雅.但是RxJava使用起来也是有副作用的,使用越来越多的订阅,内存开销也会变得很大,稍不留神就会出现内存溢出的情况,这篇文章就是介绍Rxjava使用过程中应该注意的事项. 1.取消订阅 subscription.unsubscribe()

[Android]基于RxJava、RxAndroid的EventBus实现

以下内容为原创,欢迎转载,转载请注明 来自天天博客:http://www.cnblogs.com/tiantianbyconan/p/4578699.html    Github:https://github.com/wangjiegulu/RxAndroidEventsSample EventBus的作用是发布/订阅事件总线,因为项目中用到RxJava.RxAndroid,所以完全可以使用RxJava.RxAndroid来实现EventBus.   1. 编写RxBus,用于存储所有事件Sub

RxJava 2.x 使用最佳实践

转载请标明出处:http://blog.csdn.net/zhaoyanjun6/article/details/76443347 本文出自[赵彦军的博客] 以前写过 Rxjava 系列教程, 如下所示 RxJava 和 RxAndroid 一 (基础) RxJava 和 RxAndroid 二(操作符的使用) RxJava 和 RxAndroid 三(生命周期控制和内存优化) RxJava 和 RxAndroid 四(RxBinding的使用) RxJava 和 RxAndroid 五(线程调

android 基础框架依赖库

AndroidBaseModule android base module project 基础的Android开发依赖包,独立出来主要是为了持续更新,方便多个项目同时使用,同步更新:同时使工程结构更加简洁. 使用方式 1) 新工程建议直接下载AndroidMouldProject,修改包名后在此基础上开发: or 2) Add Library module as a dependency in your build.gradle file. Add the dependency depende

【Android】RxJava之初始篇

关于RxJava RxJava是ReactiveX推出在Java VM环境下使用的异步操作库.除了在Java环境ReactiveX也为其他编程语言推出Rx库,例如Py.Js.Go等.网上有很多关于对RxJava的介绍和使用,在Android开发中也有很多项目使用RxJava.那为什么还要使用RxJava呢,Android开发也有提供异步操作的方法供开发者使用,我想应该是RxJava比起Handle.AsyncTask简洁优雅. 1 RxJava采用链式调用,在程序逻辑上清晰简洁 2 采用扩展式观

RxJava 参考文档

/*************************************************************** * RxJava 参考文档 * 说明: * 最近无意中发现RxJava这个好东西,看了几篇文档,也在 * Rx_Retrofit_Demo中简单使用了一下,这里主要是记录参考文档. * * 2016-9-5 深圳 南山平山村 曾剑锋 **************************************************************/ 一.参考

网络请求框架 Retrofit 2 使用入门

本文讲的是网络请求框架 Retrofit 2 使用入门, 你将要创造什么 Retrofit 是什么? Retrofit 是一个用于 Android 和 Java 平台的类型安全的网络请求框架.Retrofit 通过将 API 抽象成 Java 接口而让我们连接到 REST web 服务变得很轻松.在这个教程里,我会向你介绍如何使用这个 Android 上最受欢迎和经常推荐的网络请求库之一. 这个强大的库可以很简单的把返回的 JSON 或者 XML 数据解析成简单 Java 对象(POJO).GE