RxJava2_2:流程及关键对象的理解

2024-06-09 16:32
文章标签 java 流程 对象 理解 关键 rx

本文主要是介绍RxJava2_2:流程及关键对象的理解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

RxJava2:流程及关键对象的理解

参考:

http://blog.csdn.net/column/details/rxjava.html?&page=2     (这个是rxjava1的)

https://juejin.im/post/5848d96761ff4b0058c9d3dc

http://www.jianshu.com/p/404a4d9b415a

 

流程:

rxjava采用的是观察者模式,所以这个模式在理解这里很重要。其次rxjava采用的是流式处理。


管道上游和管道下游就分别对应着RxJava中的Observable和Observer,它们之间的连接就对应着subscribe();


注意: 只有当上游和下游建立连接之后, 上游才会开始发送事件. 也就是调用了subscribe() 方法之后才开始发送事件。


在emitter.onNext发出数据流之后doNext是将emitter发出的数据留作副本并行地进行处理,处理后的数据并不影响传递的observable中数据流中的数据。最后emmiter.onNext发出的数据是在观察者的onNext中得到对应的处理。

对象:

Rxjava为响应式编程,采用的是观察这模式,对其的理解都是按照观察者模式那套来理解的。

Observable为被观察者,observer为观察者。

Observable:被观察者

 

Observer:观察者

 

Flowable:是一个被观察者

 

 

Subscriber:也是一种观察者

在2.0中它与Observer没什么实质的区别,不同的是Subscriber要与Flowable(也是一种被观察者)联合使用,该部分内容是2.0新增的,Obsesrver用于订阅Observable,而Subscriber用于订阅Flowable。

 

Comsumer:观察者

如果把rxjava的观察者当做事件发生者,而comsumer就是事件消费者。在rxjava2中仍然保留了这种简化订阅方法。

 

ObservableEmitter:被观察者事件发送对象

用来发出事件的,它可以发出三种类型的事件,通过调用emitter的onNext(T value)、onComplete()和onError(Throwable error)就可以分别发出next事件、complete事件和error事件

发送事件需要满足的规则:

l   上游可以发送无限个onNext, 下游也可以接收无限个onNext.


l   当上游发送了一个onComplete后, 上游onComplete之后的事件将会继续发送, 而下游收到onComplete事件之后将不再继续接收事件.


l   当上游发送了一个onError后, 上游onError之后的事件将继续发送, 而下游收到onError事件之后将不再继续接收事件.


l   上游可以不发送onComplete或onError.

l   最为关键的是onComplete和onError必须唯一并且互斥, 即不能发多个onComplete, 也不能发多个onError, 也不能先发一个onComplete,然后再发一个onError, 反之亦然

 

Disposable:切断监测对象

可以把它理解成两根管道之间的一个机关, 当调用它的dispose()方法时, 它就会将两根管道切断, 从而导致下游收不到事件。(上游依然可以发送,只是下游不再接受)

 

Scheduler:相当于线程控制器

RxJava 通过它来指定每一段代码应该运行在什么样的线程。RxJava 已经内置了几个Scheduler ,它们已经适合大多数的使用场景,实现发送消息和接受消息在不同线程中进行的目的。

 

Flowable VS Subscriber

Observable和Observer在处理同步订阅也就是在一个线程中的时候上游发送一个事件下游接受一个事件是没有什么问题的,而当处理异步订阅也就是上游和下游不在同一个线程中时上游发送数据不需要等待下游接收, 因为两个线程并不能直接进行通信, 因此上游发送的事件并不能直接到下游里去, 上游把所有的事件发送到一个可以存储的池里面去(相当于Handler中的消息队列), 下游从队列里取出事件来处理, 因此, 当上游发事件的速度太快, 下游取事件的速度太慢, 队列就会迅速装满, 然后溢出来, 最后就OOM了.当然我们也可以通过控制上游消息的发送速度和发送数量来控制。不过Subscriber和Flowable的出现就完美的解决了OOM这个问题.



区别

1、创Flowable的时候增加了一个参数, 这个参数是用来选择背压,也就是出现上下游流速不均衡的时候应该怎么处理的办法。

2、下游的onSubscribe方法中传给我们的不再是Disposable了, 而是Subscription。

subscription.cancel()也可以切断水管, 不同的地方在于Subscription增加了一个void request(long n)方法,。Flowable在设计的时候采用了一种新的思路也就是响应式拉取的方式来更好的解决上下游流速不均衡的问题,我们把request当做是一种能力, 当成下游处理事件的能力, 下游能处理几个就告诉上游我要几个, 这样只要上游根据下游的处理能力来决定发送多少事件, 就不会造成一窝蜂的发出一堆事件来, 从而导致OOM

 

 

 

 

 

 

 

 

这篇关于RxJava2_2:流程及关键对象的理解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

Security OAuth2 单点登录流程

单点登录(英语:Single sign-on,缩写为 SSO),又译为单一签入,一种对于许多相互关连,但是又是各自独立的软件系统,提供访问控制的属性。当拥有这项属性时,当用户登录时,就可以获取所有系统的访问权限,不用对每个单一系统都逐一登录。这项功能通常是以轻型目录访问协议(LDAP)来实现,在服务器上会将用户信息存储到LDAP数据库中。相同的,单一注销(single sign-off)就是指

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

认识、理解、分类——acm之搜索

普通搜索方法有两种:1、广度优先搜索;2、深度优先搜索; 更多搜索方法: 3、双向广度优先搜索; 4、启发式搜索(包括A*算法等); 搜索通常会用到的知识点:状态压缩(位压缩,利用hash思想压缩)。