Android之RxAndroid2、RxJava2的zip应用场景及示例
Android之RxAndroid2、RxJava2的zip应用场景及示例
RxAndroid2、RxJava2的zip操作目的是为了合并两个Observable并最终发射一个单一的Observable结果。
应用场景:比如在Android APP的开发中,涉及到和后台接口交互,网络请求结果往往不是单一的一次成型完成所有操作,以一个用户登录并获取用户头像Bitmap的流程为例。
第一阶段、先登录成功,获得该用户的用户id诸如此类的必要元数据。
第二阶段、根据第一步获得的用户id然后再次发起网络请求获取该id头像的Bitmap数据,然后显示在ImageView里面。
这两阶段,虽然可以在第一阶段请求成功后再次发起第二阶段网络请求,如在Okhttp中的onSuccess里面拿到用户id,发起第二阶段的头像请求。但是代码逻辑嵌套深,不易于理解和维护。
这样的场景就比较契合RxJava2、RxAndroid2的zip的设计。
现在给出一个小例子说明:
package zhangphil.app;
import android.os.Bundle;
import android.support.annotation.NonNull;
import android.support.annotation.Nullable;
import android.support.v7.app.AppCompatActivity;
import android.util.Log;
import java.util.concurrent.Callable;
import io.reactivex.Observable;
import io.reactivex.android.schedulers.AndroidSchedulers;
import io.reactivex.disposables.CompositeDisposable;
import io.reactivex.functions.BiFunction;
import io.reactivex.observers.DisposableObserver;
import io.reactivex.schedulers.Schedulers;
public class MainActivity extends AppCompatActivity {
    private final String TAG = getClass().getSimpleName();
    private CompositeDisposable mCompositeDisposable = new CompositeDisposable();
    @Override
    public void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        addItems();
    }
    private void addItems() {
        DisposableObserver disposableObserver = new DisposableObserver<DataObject>() {
            @Override
            public void onNext(@NonNull DataObject object) {
                Log.d(TAG, "#####开始#####");
                Log.d(TAG + "数据", String.valueOf(object.A));
                Log.d(TAG + "数据", String.valueOf(object.B));
                Log.d(TAG, "#####结束#####");
            }
            @Override
            public void onComplete() {
            }
            @Override
            public void onError(Throwable e) {
                Log.e(TAG, e.toString(), e);
            }
        };
        mCompositeDisposable.add(
                Observable.zip(getObservableA(null), getObservableB(null),
                        new BiFunction<String, String, DataObject>() {
                            @Override
                            public DataObject apply(String a, String b)
                                    throws Exception {
                                DataObject object = new DataObject();
                                object.A = a;
                                object.B = b;
                                return object;
                            }
                        })
                        .subscribeOn(Schedulers.io())
                        .observeOn(AndroidSchedulers.mainThread())
                        .subscribeWith(disposableObserver));
    }
    @Override
    protected void onDestroy() {
        super.onDestroy();
        // 如果退出程序,就清除后台任务
        mCompositeDisposable.clear();
    }
    private Observable<String> getObservableA(@NonNull
    final TempObject tempObject) {
        return Observable.fromCallable(new Callable<String>() {
            @Override
            public String call() throws Exception {
                try {
                    Thread.sleep(5000); // 假设此处是耗时操作
                } catch (Exception e) {
                    e.printStackTrace();
                }
                return "A";
            }
        });
    }
    private Observable<String> getObservableB(@NonNull
    final TempObject tempObject) {
        return Observable.fromCallable(new Callable<String>() {
            @Override
            public String call() throws Exception {
                try {
                    Thread.sleep(5000); // 假设此处是耗时操作
                } catch (Exception e) {
                    e.printStackTrace();
                }
                return "B";
            }
        });
    }
    private class DataObject {
        public String A = null;
        public String B = null;
    }
    /**
     * 这是一个废弃无用的数据结构,用以演示如何在请求之间传递参数
     */
    private class TempObject {
        public String temp;
    }
}
 
 
代码运行输出:
05-12 17:36:53.614 30041-30041/zhangphil.app D/MainActivity: #####开始#####
05-12 17:36:53.615 30041-30041/zhangphil.app D/MainActivity数据: A
05-12 17:36:53.615 30041-30041/zhangphil.app D/MainActivity数据: B
05-12 17:36:53.616 30041-30041/zhangphil.app D/MainActivity: #####结束#####
 
 
关注公众号
					低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 
							
								
								    上一篇
								    
								
								Minimum supported Gradle version is 2.14.1
起因:长时间一直使用的Gradle版本是2.10-all;我的iMac版本采用的是2.14.1,不小心将Gradle版本配置信息提交; 导致winPC不能正常使用 并且控制台提示 Error:(1, 1) A problem occurred evaluating project ':app'. > Failed to apply plugin [id 'com.android.application'] > Minimum supported Gradle version is 2.14.1. Current version is 2.10. If using the gradle wrapper, try editing the 问题:很简单就是网络(fan)不能(qiang)下载gradle2.14.1版本 解决:找到AndroidStudio安装目录,进入gradle,然后把下载的gradle-2.14解压进去即可。 1、下载Gradle2.14.1 免积分下载Gradle2.14.1 2、解压到AS指定目录 ...
 - 
							
								
								    下一篇
								    
								
								FreeSWITCH第三方库(视频)的简单介绍(二)
FreeSWITCH使用了大量的第三方库,本文档主要介绍视频相关库的信息: 音频相关库的信息介绍参考:http://www.cnblogs.com/yoyotl/p/5486753.html 其他相关库的信息介绍参考:http://www.cnblogs.com/yoyotl/p/5489315.html ① openh264 OpenH264 是思科公司以BSD协议开放的一个开源的 H.264 编码器和解码器。 Cisco 将以 BSD 协议开放其 H264 解码器实现,并提供针对主流操作系统的预编译库文件下载。Cisco 将负责承担 MPEG LA 的专利使用费,并和 Mozilla 共同管理 OpenH264 开源项目。 Firefox 以后默认支持H264,但依然支持 VP8 格式,并可在 WebRTC 中使用。 Mozilla 已经组成了开源编码器专家小组开发下一代无专利限制视频编码格式 Daala,将以与 H265 和 VP9 截然不同的方式绕过可能的专利雷区。但是依然还需要解决同样被专利困扰的 AAC 音频解码器。 ② libav Libav是一个自由软件,可以执行音...
 
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- MySQL8.0.19开启GTID主从同步CentOS8
 - CentOS8安装MyCat,轻松搞定数据库的读写分离、垂直分库、水平分库
 - MySQL数据库在高并发下的优化方案
 - CentOS8,CentOS7,CentOS6编译安装Redis5.0.7
 - Docker快速安装Oracle11G,搭建oracle11g学习环境
 - CentOS7编译安装Cmake3.16.3,解决mysql等软件编译问题
 - Docker使用Oracle官方镜像安装(12C,18C,19C)
 - CentOS7,CentOS8安装Elasticsearch6.8.6
 - Hadoop3单机部署,实现最简伪集群
 - CentOS7,8上快速安装Gitea,搭建Git服务器
 

			
				
				
				
				
				
				
				
微信收款码
支付宝收款码