Carson带你学Android:RxJava创建操作符

2023-10-15 00:50

本文主要是介绍Carson带你学Android:RxJava创建操作符,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

Rxjava,由于其基于事件流的链式调用、逻辑简洁 & 使用简单的特点,深受各大 Android开发者的欢迎。

Github截图

  • 今天,我将为大家详细介绍RxJava操作符中最常用的创建操作符,并附带 Retrofit 结合 RxJava的实例Demo教学,希望你们会喜欢。

Carson带你学RxJava系列文章,包括 原理、操作符、应用场景、背压等等,请看文章:Android:这是一份全面 & 详细的RxJava学习指南


目录

示意图


1. 作用

创建 被观察者( Observable) 对象 & 发送事件。


2. 类型

  • 创建操作符包括如下:

示意图

  • 下面,我将对每个操作符进行详细介绍

3. 应用场景 & 对应操作符 介绍

注:在使用RxJava 2操作符前,记得在项目的Gradle中添加依赖:

dependencies {compile 'io.reactivex.rxjava2:rxandroid:2.0.1'compile 'io.reactivex.rxjava2:rxjava:2.0.7'// 注:RxJava2 与 RxJava1 不能共存,即依赖不能同时存在
}

3.1 基本创建

  • 需求场景
    完整的创建被观察者对象

  • 对应操作符类型

create()

  • 作用
    完整创建1个被观察者对象(Observable

RxJava 中创建被观察者对象最基本的操作符

  • 具体使用
/ *** 1. 通过creat()创建被观察者 Observable 对象*/ Observable<Integer> observable = Observable.create(new ObservableOnSubscribe<Integer>() {// 传入参数: OnSubscribe 对象// 当 Observable 被订阅时,OnSubscribe 的 call() 方法会自动被调用,即事件序列就会依照设定依次被触发// 即观察者会依次调用对应事件的复写方法从而响应事件// 从而实现由被观察者向观察者的事件传递 & 被观察者调用了观察者的回调方法 ,即观察者模式
/ *** 2. 在复写的subscribe()里定义需要发送的事件*/ @Overridepublic void subscribe(ObservableEmitter<Integer> emitter) throws Exception {// 通过 ObservableEmitter类对象 产生 & 发送事件// ObservableEmitter类介绍// a. 定义:事件发射器// b. 作用:定义需要发送的事件 & 向观察者发送事件// 注:建议发送事件前检查观察者的isUnsubscribed状态,以便在没有观察者时,让Observable停止发射数据if (!observer.isUnsubscribed()) {emitter.onNext(1);emitter.onNext(2);emitter.onNext(3);}emitter.onComplete();}});// 至此,一个完整的被观察者对象(Observable)就创建完毕了。

在具体使用时,一般采用 链式调用 来创建

        // 1. 通过creat()创建被观察者对象Observable.create(new ObservableOnSubscribe<Integer>() {// 2. 在复写的subscribe()里定义需要发送的事件@Overridepublic void subscribe(ObservableEmitter<Integer> emitter) throws Exception {emitter.onNext(1);emitter.onNext(2);emitter.onNext(3);emitter.onComplete();}  // 至此,一个被观察者对象(Observable)就创建完毕}).subscribe(new Observer<Integer>() {// 以下步骤仅为展示一个完整demo,可以忽略// 3. 通过通过订阅(subscribe)连接观察者和被观察者// 4. 创建观察者 & 定义响应事件的行为@Overridepublic void onSubscribe(Disposable d) {Log.d(TAG, "开始采用subscribe连接");}// 默认最先调用复写的 onSubscribe()@Overridepublic void onNext(Integer value) {Log.d(TAG, "接收到了事件"+ value  );}@Overridepublic void onError(Throwable e) {Log.d(TAG, "对Error事件作出响应");}@Overridepublic void onComplete() {Log.d(TAG, "对Complete事件作出响应");}});}
  • 测试结果

示意图

3.2 快速创建 & 发送事件

  • 需求场景
    快速的创建被观察者对象

  • 对应操作符类型

just()

  • 作用
    1. 快速创建1个被观察者对象(Observable
    2. 发送事件的特点:直接发送 传入的事件

注:最多只能发送10个参数

  • 应用场景
    快速创建 被观察者对象(Observable) & 发送10个以下事件

  • 具体使用

        // 1. 创建时传入整型1、2、3、4// 在创建后就会发送这些对象,相当于执行了onNext(1)、onNext(2)、onNext(3)、onNext(4)Observable.just(1, 2, 3,4)   // 至此,一个Observable对象创建完毕,以下步骤仅为展示一个完整demo,可以忽略// 2. 通过通过订阅(subscribe)连接观察者和被观察者// 3. 创建观察者 & 定义响应事件的行为.subscribe(new Observer<Integer>() {@Overridepublic void onSubscribe(Disposable d) {Log.d(TAG, "开始采用subscribe连接");}// 默认最先调用复写的 onSubscribe()@Overridepublic void onNext(Integer value) {Log.d(TAG, "接收到了事件"+ value  );}@Overridepublic void onError(Throwable e) {Log.d(TAG, "对Error事件作出响应");}@Overridepublic void onComplete() {Log.d(TAG, "对Complete事件作出响应");}});}
  • 测试结果

示意图

fromArray()

  • 作用
    1. 快速创建1个被观察者对象(Observable
    2. 发送事件的特点:直接发送 传入的数组数据

会将数组中的数据转换为Observable对象

  • 应用场景

    1. 快速创建 被观察者对象(Observable) & 发送10个以上事件(数组形式)
    2. 数组元素遍历
  • 具体使用

      // 1. 设置需要传入的数组Integer[] items = { 0, 1, 2, 3, 4 };// 2. 创建被观察者对象(Observable)时传入数组// 在创建后就会将该数组转换成Observable & 发送该对象中的所有数据Observable.fromArray(items) .subscribe(new Observer<Integer>() {@Overridepublic void onSubscribe(Disposable d) {Log.d(TAG, "开始采用subscribe连接");}@Overridepublic void onNext(Integer value) {Log.d(TAG, "接收到了事件"+ value  );}@Overridepublic void onError(Throwable e) {Log.d(TAG, "对Error事件作出响应");}@Overridepublic void onComplete() {Log.d(TAG, "对Complete事件作出响应");}});}// 注:
// 可发送10个以上参数
// 若直接传递一个list集合进去,否则会直接把list当做一个数据元素发送/** 数组遍历**/// 1. 设置需要传入的数组Integer[] items = { 0, 1, 2, 3, 4 };// 2. 创建被观察者对象(Observable)时传入数组// 在创建后就会将该数组转换成Observable & 发送该对象中的所有数据Observable.fromArray(items).subscribe(new Observer<Integer>() {@Overridepublic void onSubscribe(Disposable d) {Log.d(TAG, "数组遍历");}@Overridepublic void onNext(Integer value) {Log.d(TAG, "数组中的元素 = "+ value  );}@Overridepublic void onError(Throwable e) {Log.d(TAG, "对Error事件作出响应");}@Overridepublic void onComplete() {Log.d(TAG, "遍历结束");}});
  • 测试结果

发送事件

数组遍历

fromIterable()

  • 作用
    1. 快速创建1个被观察者对象(Observable
    2. 发送事件的特点:直接发送 传入的集合List数据

会将数组中的数据转换为Observable对象

  • 应用场景

    1. 快速创建 被观察者对象(Observable) & 发送10个以上事件(集合形式)
    2. 集合元素遍历
  • 具体使用

/** 快速发送集合**/
// 1. 设置一个集合List<Integer> list = new ArrayList<>();list.add(1);list.add(2);list.add(3);// 2. 通过fromIterable()将集合中的对象 / 数据发送出去Observable.fromIterable(list).subscribe(new Observer<Integer>() {@Overridepublic void onSubscribe(Disposable d) {Log.d(TAG, "开始采用subscribe连接");}@Overridepublic void onNext(Integer value) {Log.d(TAG, "接收到了事件"+ value  );}@Overridepublic void onError(Throwable e) {Log.d(TAG, "对Error事件作出响应");}@Overridepublic void onComplete() {Log.d(TAG, "对Complete事件作出响应");}});/** 集合遍历**/// 1. 设置一个集合List<Integer> list = new ArrayList<>();list.add(1);list.add(2);list.add(3);// 2. 通过fromIterable()将集合中的对象 / 数据发送出去Observable.fromIterable(list).subscribe(new Observer<Integer>() {@Overridepublic void onSubscribe(Disposable d) {Log.d(TAG, "集合遍历");}@Overridepublic void onNext(Integer value) {Log.d(TAG, "集合中的数据元素 = "+ value  );}@Overridepublic void onError(Throwable e) {Log.d(TAG, "对Error事件作出响应");}@Overridepublic void onComplete() {Log.d(TAG, "遍历结束");}});
  • 测试结果

发送集合

集合遍历

额外

// 下列方法一般用于测试使用<-- empty()  -->
// 该方法创建的被观察者对象发送事件的特点:仅发送Complete事件,直接通知完成
Observable observable1=Observable.empty(); 
// 即观察者接收后会直接调用onCompleted()<-- error()  -->
// 该方法创建的被观察者对象发送事件的特点:仅发送Error事件,直接通知异常
// 可自定义异常
Observable observable2=Observable.error(new RuntimeException())
// 即观察者接收后会直接调用onError()<-- never()  -->
// 该方法创建的被观察者对象发送事件的特点:不发送任何事件
Observable observable3=Observable.never();
// 即观察者接收后什么都不调用

3.3 延迟创建

  • 需求场景
    1. 定时操作:在经过了x秒后,需要自动执行y操作
    2. 周期性操作:每隔x秒后,需要自动执行y操作

defer()

  • 作用
    直到有观察者(Observer )订阅时,才动态创建被观察者对象(Observable) & 发送事件
  1. 通过 Observable工厂方法创建被观察者对象(Observable
  2. 每次订阅后,都会得到一个刚创建的最新的Observable对象,这可以确保Observable对象里的数据是最新的
  • 应用场景
    动态创建被观察者对象(Observable) & 获取最新的Observable对象数据

  • 具体使用

       <-- 1. 第1次对i赋值 ->>Integer i = 10;// 2. 通过defer 定义被观察者对象// 注:此时被观察者对象还没创建Observable<Integer> observable = Observable.defer(new Callable<ObservableSource<? extends Integer>>() {@Overridepublic ObservableSource<? extends Integer> call() throws Exception {return Observable.just(i);}});<-- 2. 第2次对i赋值 ->>i = 15;<-- 3. 观察者开始订阅 ->>// 注:此时,才会调用defer()创建被观察者对象(Observable)observable.subscribe(new Observer<Integer>() {@Overridepublic void onSubscribe(Disposable d) {Log.d(TAG, "开始采用subscribe连接");}@Overridepublic void onNext(Integer value) {Log.d(TAG, "接收到的整数是"+ value  );}@Overridepublic void onError(Throwable e) {Log.d(TAG, "对Error事件作出响应");}@Overridepublic void onComplete() {Log.d(TAG, "对Complete事件作出响应");}});
  • 测试结果

因为是在订阅时才创建,所以i值会取第2次的赋值
示意图

timer()

  • 作用
    1. 快速创建1个被观察者对象(Observable
    2. 发送事件的特点:延迟指定时间后,发送1个数值0(Long类型)

本质 = 延迟指定时间后,调用一次 onNext(0)

  • 应用场景
    延迟指定事件,发送一个0,一般用于检测

  • 具体使用

        // 该例子 = 延迟2s后,发送一个long类型数值Observable.timer(2, TimeUnit.SECONDS) .subscribe(new Observer<Long>() {@Overridepublic void onSubscribe(Disposable d) {Log.d(TAG, "开始采用subscribe连接");}@Overridepublic void onNext(Long value) {Log.d(TAG, "接收到了事件"+ value  );}@Overridepublic void onError(Throwable e) {Log.d(TAG, "对Error事件作出响应");}@Overridepublic void onComplete() {Log.d(TAG, "对Complete事件作出响应");}});// 注:timer操作符默认运行在一个新线程上
// 也可自定义线程调度器(第3个参数):timer(long,TimeUnit,Scheduler) 
  • 测试结果

示意图

interval()

  • 作用
    1. 快速创建1个被观察者对象(Observable
    2. 发送事件的特点:每隔指定时间 就发送 事件

发送的事件序列 = 从0开始、无限递增1的的整数序列

  • 具体使用
       // 参数说明:// 参数1 = 第1次延迟时间;// 参数2 = 间隔时间数字;// 参数3 = 时间单位;Observable.interval(3,1,TimeUnit.SECONDS)// 该例子发送的事件序列特点:延迟3s后发送事件,每隔1秒产生1个数字(从0开始递增1,无限个).subscribe(new Observer<Long>() {@Overridepublic void onSubscribe(Disposable d) {Log.d(TAG, "开始采用subscribe连接");}// 默认最先调用复写的 onSubscribe()@Overridepublic void onNext(Long value) {Log.d(TAG, "接收到了事件"+ value  );}@Overridepublic void onError(Throwable e) {Log.d(TAG, "对Error事件作出响应");}@Overridepublic void onComplete() {Log.d(TAG, "对Complete事件作出响应");}});// 注:interval默认在computation调度器上执行
// 也可自定义指定线程调度器(第3个参数):interval(long,TimeUnit,Scheduler)
  • 测试结果

示意图

intervalRange()

  • 作用
    1. 快速创建1个被观察者对象(Observable
    2. 发送事件的特点:每隔指定时间 就发送 事件,可指定发送的数据的数量

a. 发送的事件序列 = 从0开始、无限递增1的的整数序列
b. 作用类似于interval(),但可指定发送的数据的数量

  • 具体使用
// 参数说明:// 参数1 = 事件序列起始点;// 参数2 = 事件数量;// 参数3 = 第1次事件延迟发送时间;// 参数4 = 间隔时间数字;// 参数5 = 时间单位Observable.intervalRange(3,10,2, 1, TimeUnit.SECONDS)// 该例子发送的事件序列特点:// 1. 从3开始,一共发送10个事件;// 2. 第1次延迟2s发送,之后每隔2秒产生1个数字(从0开始递增1,无限个).subscribe(new Observer<Long>() {@Overridepublic void onSubscribe(Disposable d) {Log.d(TAG, "开始采用subscribe连接");}// 默认最先调用复写的 onSubscribe()@Overridepublic void onNext(Long value) {Log.d(TAG, "接收到了事件"+ value  );}@Overridepublic void onError(Throwable e) {Log.d(TAG, "对Error事件作出响应");}@Overridepublic void onComplete() {Log.d(TAG, "对Complete事件作出响应");}});
  • 测试结果

示意图

range()

  • 作用
    1. 快速创建1个被观察者对象(Observable
    2. 发送事件的特点:连续发送 1个事件序列,可指定范围

a. 发送的事件序列 = 从0开始、无限递增1的的整数序列
b. 作用类似于intervalRange(),但区别在于:无延迟发送事件

  • 具体使用

// 参数说明:// 参数1 = 事件序列起始点;// 参数2 = 事件数量;// 注:若设置为负数,则会抛出异常Observable.range(3,10)// 该例子发送的事件序列特点:从3开始发送,每次发送事件递增1,一共发送10个事件.subscribe(new Observer<Integer>() {@Overridepublic void onSubscribe(Disposable d) {Log.d(TAG, "开始采用subscribe连接");}// 默认最先调用复写的 onSubscribe()@Overridepublic void onNext(Integer value) {Log.d(TAG, "接收到了事件"+ value  );}@Overridepublic void onError(Throwable e) {Log.d(TAG, "对Error事件作出响应");}@Overridepublic void onComplete() {Log.d(TAG, "对Complete事件作出响应");}});
  • 测试结果

示意图

rangeLong()

  • 作用:类似于range(),区别在于该方法支持数据类型 = Long
  • 具体使用
    range()类似,此处不作过多描述

至此,关于 RxJava2中的创建操作符讲解完毕。


4. 实际开发需求案例

  • 下面,我将讲解创建操作符的1个常见实际需求案例:网络请求轮询
  • 该例子将结合RetrofitRxJava 进行讲解

具体请看文章:Android RxJava 实际应用案例讲解:网络请求轮询


5. Demo地址

上述所有的Demo源代码都存放在:Carson_Ho的Github地址:RxJava2_创建操作符


6. 总结

  • 下面,我将用1张图总结 RxJava2 中常用的创建操作符

示意图

Carson带你学RxJava系列文章:

入门
Carson带你学Android:这是一篇清晰易懂的Rxjava入门教程
Carson带你学Android:这是一份面向初学者的RxJava使用指南
Carson带你学Android:RxJava2.0到底更新了什么?(含使用建议)
原理
Carson带你学Android:图文解析RxJava原理
Carson带你学Android:手把手带你源码分析RxJava
使用教程(操作符)
Carson带你学Android:RxJava操作符教程
Carson带你学Android:RxJava创建操作符
Carson带你学Android:RxJava功能性操作符
Carson带你学Android:RxJava过滤操作符
Carson带你学Android:RxJava组合/合并操作符
Carson带你学Android:RxJava变换操作符
Carson带你学Android:RxJava条件/布尔操作符
应用
Carson带你学Android:什么时候应该使用Rxjava?(开发场景汇总)
Carson带你学Android:RxJava线程控制(含实例讲解)
Carson带你学Android:图文详解RxJava背压策略
Carson带你学Android:RxJava、Retrofit联合使用汇总(含实例教程)
Carson带你学Android:优雅实现网络请求嵌套回调
Carson带你学Android:网络请求轮询(有条件)
Carson带你学Android:网络请求轮询(无条件)
Carson带你学Android:网络请求出错重连(结合Retrofit)
Carson带你学Android:合并数据源
Carson带你学Android:联想搜索优化
Carson带你学Android:功能防抖
Carson带你学Android:从磁盘/内存缓存中获取缓存数据
Carson带你学Android:联合判断


欢迎关注Carson_Ho的CSDN博客 与 公众号!

博客链接:https://carsonho.blog.csdn.net/


请帮顶 / 评论点赞!因为你的鼓励是我写作的最大动力!

这篇关于Carson带你学Android:RxJava创建操作符的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/214285

相关文章

SpringSecurity显示用户账号已被锁定的原因及解决方案

《SpringSecurity显示用户账号已被锁定的原因及解决方案》SpringSecurity中用户账号被锁定问题源于UserDetails接口方法返回值错误,解决方案是修正isAccountNon... 目录SpringSecurity显示用户账号已被锁定的解决方案1.问题出现前的工作2.问题出现原因各

Java继承映射的三种使用方法示例

《Java继承映射的三种使用方法示例》继承在Java中扮演着重要的角色,它允许我们创建一个类(子类),该类继承另一个类(父类)的所有属性和方法,:本文主要介绍Java继承映射的三种使用方法示例,需... 目录前言一、单表继承(Single Table Inheritance)1-1、原理1-2、使用方法1-

Android DataBinding 与 MVVM使用详解

《AndroidDataBinding与MVVM使用详解》本文介绍AndroidDataBinding库,其通过绑定UI组件与数据源实现自动更新,支持双向绑定和逻辑运算,减少模板代码,结合MV... 目录一、DataBinding 核心概念二、配置与基础使用1. 启用 DataBinding 2. 基础布局

Android ViewBinding使用流程

《AndroidViewBinding使用流程》AndroidViewBinding是Jetpack组件,替代findViewById,提供类型安全、空安全和编译时检查,代码简洁且性能优化,相比Da... 目录一、核心概念二、ViewBinding优点三、使用流程1. 启用 ViewBinding (模块级

Spring @Scheduled注解及工作原理

《Spring@Scheduled注解及工作原理》Spring的@Scheduled注解用于标记定时任务,无需额外库,需配置@EnableScheduling,设置fixedRate、fixedDe... 目录1.@Scheduled注解定义2.配置 @Scheduled2.1 开启定时任务支持2.2 创建

SpringBoot中使用Flux实现流式返回的方法小结

《SpringBoot中使用Flux实现流式返回的方法小结》文章介绍流式返回(StreamingResponse)在SpringBoot中通过Flux实现,优势包括提升用户体验、降低内存消耗、支持长连... 目录背景流式返回的核心概念与优势1. 提升用户体验2. 降低内存消耗3. 支持长连接与实时通信在Sp

MySQL 用户创建与授权最佳实践

《MySQL用户创建与授权最佳实践》在MySQL中,用户管理和权限控制是数据库安全的重要组成部分,下面详细介绍如何在MySQL中创建用户并授予适当的权限,感兴趣的朋友跟随小编一起看看吧... 目录mysql 用户创建与授权详解一、MySQL用户管理基础1. 用户账户组成2. 查看现有用户二、创建用户1. 基

Spring Boot 实现 IP 限流的原理、实践与利弊解析

《SpringBoot实现IP限流的原理、实践与利弊解析》在SpringBoot中实现IP限流是一种简单而有效的方式来保障系统的稳定性和可用性,本文给大家介绍SpringBoot实现IP限... 目录一、引言二、IP 限流原理2.1 令牌桶算法2.2 漏桶算法三、使用场景3.1 防止恶意攻击3.2 控制资源

Mac系统下卸载JAVA和JDK的步骤

《Mac系统下卸载JAVA和JDK的步骤》JDK是Java语言的软件开发工具包,它提供了开发和运行Java应用程序所需的工具、库和资源,:本文主要介绍Mac系统下卸载JAVA和JDK的相关资料,需... 目录1. 卸载系统自带的 Java 版本检查当前 Java 版本通过命令卸载系统 Java2. 卸载自定

springboot下载接口限速功能实现

《springboot下载接口限速功能实现》通过Redis统计并发数动态调整每个用户带宽,核心逻辑为每秒读取并发送限定数据量,防止单用户占用过多资源,确保整体下载均衡且高效,本文给大家介绍spring... 目录 一、整体目标 二、涉及的主要类/方法✅ 三、核心流程图解(简化) 四、关键代码详解1️⃣ 设置