RxJava2操作符之“Scan”作用示例用法运行结果分析总结

作用

扫描,遍历,用法和上一个Reduce操作符差不多,只是这个操作符会将每一个过程的中间产物发射出来,而不是只发射结果

示例用法

这里举个例子,做一下累加计算

 Observable.just(1, 2, 3, 4,5)//创建了一个有5个数字的被观察者
                .scan(new BiFunction<Integer, Integer, Integer>() {
                    @Override
                    public Integer apply(Integer t1, Integer t2) {
                        return t1 + t2;//累加操作,如果是-就是累减操作。。依此类推
                    }
                })
                .subscribe(getObserver())//这里的观察者依然不重要

这里前两个数计算的结果会作为第二个计算的t1传进来,直到处理完最后一次计算

运行结果

1,3,6,10,15

分析

我们的被观察者中有5个数,分别是1,2,3,4,5 scan的过程: 第一个参数1不够两个,直接发射结果1; 之后: t1 = 1;t2 = 2 计算:t1 + t2 = 3,发射结果3; t1 = 3;t2 = 3; 计算: t1 + t2 = 6,发射结果6; t1 = 6;t2 = 4; 计算 :t1 + t2 = 10,发射结果10; t1 = 10;t2 = 5; 计算 :t1 + t2 = 15,发射结果15; 结束

总结

这个系列只有干货,如果大家有什么好的建议的话欢迎在下面评论。或者觉得我哪里写的不够形象了,同样可以提出来。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏xingoo, 一个梦想做发明家的程序员

快速排序

算法思想:对于输入的子数组a[p:r],按下面三个步骤: 1 分解:以a[p]为基准元素将a[p:r]分成三段,a[p:q-1],a[q],a[q+1:r],使...

2109
来自专栏java工会

java冒泡排序和快速排序

3393
来自专栏GreenLeaves

Oracle dbms_random随机函数包

dbms_random是oracle提供的一个随机函数包,以下是它的一些常用的功能: 1、dbms_random.value 作用:生成一个大于等于0,大于等于...

2135
来自专栏Java技术栈

神奇,教你用随机数打印hello world

下面是一段随机数程序。 public static void main(String[] args) { System.out.println(rand...

3695
来自专栏伪君子的梦呓

leetcode 题解~两数之和 ~ C++做法

1875
来自专栏小樱的经验随笔

洛谷 P1019 单词接龙【经典DFS,温习搜索】

P1019 单词接龙 题目描述 单词接龙是一个与我们经常玩的成语接龙相类似的游戏,现在我们已知一组单词,且给定一个开头的字母,要求出以这个字母开头的最长的“龙”...

3866
来自专栏owent

最长单调子序列 复杂度nlog(n)

791
来自专栏数据结构与算法

P3809 【模版】后缀排序

题目背景 这是一道模版题。 题目描述 读入一个长度为 nn 的由大小写英文字母或数字组成的字符串,请把这个字符串的所有非空后缀按字典序从小到大排序,然后按顺序输...

2678
来自专栏数据结构与算法

BZOJ2212: [Poi2011]Tree Rotations(线段树合并)

可以证明,对于\(m\)个仅有一个元素,权值范围在\([1, n]\)的线段树合并的复杂度为\(mlogn\)

782
来自专栏数据结构与算法

洛谷P3273 [SCOI2011]棘手的操作

题目描述 有N个节点,标号从1到N,这N个节点一开始相互不连通。第i个节点的初始权值为a[i],接下来有如下一些操作:U x y: 加一条边,连接第x个节点和第...

3327

扫码关注云+社区

领取腾讯云代金券