决策树

创建一个Observable

1.产生特定的一个元素:just

  • 经过一段延时:timer

2.从一个序列拉取元素:from
3.重复的产生某一个元素:repeatElement
4.存在自定义逻辑:create
5.每次订阅时产生:deferred
6.每隔一段时间,发出一个元素:interval

  • 在一段延时后:timer

7.一个空序列,只有一个完成事件:empty
8.一个任何事件都没有产生的序列:never

创建一个 Observable 通过组合其他的 Observables

1.任意一个 Observable 产生了元素,就发出这个元素:merge
2.让这些 Observables 一个接一个的发出元素,当上一个 Observable 元素发送完毕后,下一个 Observable 才能开始发出元素:concat
3.组合多个 Observables 的元素

  • 当每一个 Observable 都发出一个新的元素:zip
  • 当任意一个 Observable 发出一个新的元素:combineLatest

转换 Observable 的元素后,再将它们发出来

1.对每个元素直接转换:map
2.转换到另一个 Observable:flatMap

  • 只接收最新的元素转换的 Observable 所产生的元素:flatMapLatest
  • 每一个元素转换的 Observable 按顺序产生元素:concatMap

3.基于所有遍历过的元素: scan

将产生的每一个元素,拖延一段时间后再发出:delay

将产生的事件封装成元素发送出来

将他们封装成 Event<Element>:materialize

  • 然后解封出来:dematerialize

忽略掉所有的 next 事件,只接收 completed 和 error 事件:ignoreElements

创建一个新的 Observable 在原有的序列前面加入一些元素:startWith

从 Observable 中收集元素,缓存这些元素之后在发出:buffer

将 Observable 拆分成多个 Observables:window

基于元素的共同特征:groupBy

只接收 Observable 中特定的元素

发出唯一的元素:single

重新从 Observable 中发出某些元素

1.通过判定条件过滤出一些元素:filter
2.仅仅发出头几个元素:take
3.仅仅发出尾部的几个元素:takeLast
4.仅仅发出第 n 个元素:elementAt
5.跳过头几个元素

  • 跳过头 n 个元素:skip
  • 跳过头几个满足判定的元素:skipWhile,skipWhileWithIndex
  • 跳过某段时间内产生的头几个元素:skip
  • 跳过头几个元素直到另一个 Observable 发出一个元素:skipUntil

6.只取头几个元素

  • 只取头几个满足判定的元素:takeWhile,takeWhileWithIndex
  • 只取某段时间内产生的头几个元素:take
  • 只取头几个元素直到另一个 Observable 发出一个元素:takeUntil

7.周期性的对 Observable 抽样:sample
8.发出那些元素,这些元素产生后的特定的时间内,没有新的元素产生:debounce
9.直到元素的值发生变化,才发出新的元素:distinctUntilChanged

  • 并提供元素是否相等的判定函数:distinctUntilChanged

10.在开始发出元素时,延时后进行订阅:delaySubscription

从一些 Observables 中,只取第一个产生元素的 Observable:amb

评估 Observable 的全部元素

1.并且对每个元素应用聚合方法,待所有元素都应用聚合方法后,发出结果:reduce
2.并且对每个元素应用聚合方法,每次应用聚合方法后,发出结果:scan

把 Observable 转换为其他的数据结构:as...

在某个 Scheduler 应用操作符:subscribeOn

在某个 Scheduler 监听:observeOn

要 Observable 发生某个事件时, 采取某个行动:do

要 Observable 发出一个 error 事件:error

如果规定时间内没有产生元素:timeout

要 Observable 发生错误时,优雅的恢复

1.如果规定时间内没有产生元素,就切换到备选 Observable :timeout
2.如果产生错误,将错误替换成某个元素 :catchErrorJustReturn
3.如果产生错误,就切换到备选 Observable :catchError
4.如果产生错误,就重试 :retry

创建一个 Disposable 资源,使它与 Observable 具有相同的寿命:using

创建一个 Observable,直到我通知它可以产生元素后,才能产生元素:publish

1.并且,就算是在产生元素后订阅,也要发出全部元素:replay
2.并且,一旦所有观察者取消观察,他就被释放掉:refCount
3.通知它可以产生元素了:connect

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 157,198评论 4 359
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 66,663评论 1 290
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 106,985评论 0 237
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,673评论 0 202
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 51,994评论 3 285
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,399评论 1 211
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,717评论 2 310
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,407评论 0 194
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,112评论 1 239
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,371评论 2 241
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 31,891评论 1 256
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,255评论 2 250
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 32,881评论 3 233
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,010评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,764评论 0 192
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,412评论 2 269
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,299评论 2 260

推荐阅读更多精彩内容