RxJava背壓

訂閱分為:同步訂閱 異步訂閱

同步訂閱Rxjava1與Rxjava2中 同步訂閱沒有用到緩沖區(qū)扩氢,只要上游事件數(shù)量不大于請(qǐng)求數(shù)量不會(huì)觸發(fā) MissingBackpressureException 異常留攒,但是這種方式在數(shù)量多了以后會(huì)出現(xiàn)大量的內(nèi)存使用率上升蚂维,有可能導(dǎo)致OOM陶耍。

同步訂閱赏陵,存在問題徒像,因?yàn)椴淮嬖诰彌_區(qū),發(fā)送事件超過接收事件拋出異常笨枯。這種可以通過 FlowableEmitter類的requested()控制被觀察者發(fā)送速度薪丁,就是發(fā)送前先獲取到觀察者能接收多少個(gè)遇西。異步訂閱Rxjava1中的Observable與少量的操作符采用了背壓處理馅精。但是緩沖區(qū)的大小為16,如果上游數(shù)據(jù)超過16個(gè)同時(shí)發(fā)送事件會(huì)觸發(fā)MissBackPressureException粱檀。

Rxjava2中的Observalbe不在支持背壓策略洲敢。但是新增了Flowable支持背壓策略。相對(duì)同步訂閱存在緩沖區(qū)茄蚯,多發(fā)送的事件會(huì)被存在緩沖區(qū)压彭。事件積壓超過一定數(shù)量會(huì)拋出MissingBackpressureException。

RxJava2采取了更先進(jìn)的背壓

策略模式1:BackpressureStrategy.ERROR?

問題:發(fā)送事件速度 > 接收事件 速度渗常,即流速不匹配具體

表現(xiàn):出現(xiàn)當(dāng)緩存區(qū)大小存滿(默認(rèn)緩存區(qū)大小 = 128)壮不、被觀察者仍然繼續(xù)發(fā)送下1個(gè)事件時(shí)

處理方式:直接拋出異常MissingBackpressureException


模式2:BackpressureStrategy.MISSING

問題:發(fā)送事件速度 > 接收事件 速度,即流速不匹配

具體表現(xiàn)是:出現(xiàn)當(dāng)緩存區(qū)大小存滿(默認(rèn)緩存區(qū)大小 = 128)皱碘、被觀察者仍然繼續(xù)發(fā)送下1個(gè)事件時(shí)

處理方式:友好提示:緩存區(qū)滿了


模式3:BackpressureStrategy.BUFFER

問題:發(fā)送事件速度 > 接收事件 速度询一,即流速不匹配

具體表現(xiàn)是:出現(xiàn)當(dāng)緩存區(qū)大小存滿(默認(rèn)緩存區(qū)大小 = 128)、被觀察者仍然繼續(xù)發(fā)送下1個(gè)事件時(shí)

處理方式:將緩存區(qū)大小設(shè)置成無限大?即被觀察者可無限發(fā)送事件觀察者癌椿,但實(shí)際上是存放在緩存區(qū)?但要注意內(nèi)存情況健蕊,防止出現(xiàn)OOM


模式4: BackpressureStrategy.DROP

問題:發(fā)送事件速度 > 接收事件 速度,即流速不匹配

具體表現(xiàn)是:出現(xiàn)當(dāng)緩存區(qū)大小存滿(默認(rèn)緩存區(qū)大小 = 128)踢俄、被觀察者仍然繼續(xù)發(fā)送下1個(gè)事件時(shí)

處理方式:超過緩存區(qū)大兴豕Α(128)的事件丟棄?如發(fā)送了150個(gè)事件,僅保存第1 - 第128個(gè)事件都办,第129 -第150事件將被丟棄


模式5:BackpressureStrategy.LATEST

問題:發(fā)送事件速度 > 接收事件 速度嫡锌,即流速不匹配

具體表現(xiàn)是:出現(xiàn)當(dāng)緩存區(qū)大小存滿(默認(rèn)緩存區(qū)大小 = 128)、被觀察者仍然繼續(xù)發(fā)送下1個(gè)事件時(shí)

處理方式:只保存最新(最后)事件琳钉,超過緩存區(qū)大惺澜ⅰ(128)的事件丟棄?即如果發(fā)送了150個(gè)事件,緩存區(qū)里會(huì)保存129個(gè)事件(第1-第128 + 第150事件)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末槽卫,一起剝皮案震驚了整個(gè)濱河市跟压,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌歼培,老刑警劉巖震蒋,帶你破解...
    沈念sama閱讀 219,366評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件茸塞,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡查剖,警方通過查閱死者的電腦和手機(jī)钾虐,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,521評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來笋庄,“玉大人效扫,你說我怎么就攤上這事≈鄙埃” “怎么了菌仁?”我有些...
    開封第一講書人閱讀 165,689評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)静暂。 經(jīng)常有香客問我济丘,道長(zhǎng),這世上最難降的妖魔是什么洽蛀? 我笑而不...
    開封第一講書人閱讀 58,925評(píng)論 1 295
  • 正文 為了忘掉前任摹迷,我火速辦了婚禮,結(jié)果婚禮上郊供,老公的妹妹穿的比我還像新娘峡碉。我一直安慰自己,他們只是感情好驮审,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,942評(píng)論 6 392
  • 文/花漫 我一把揭開白布鲫寄。 她就那樣靜靜地躺著,像睡著了一般头岔。 火紅的嫁衣襯著肌膚如雪塔拳。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,727評(píng)論 1 305
  • 那天峡竣,我揣著相機(jī)與錄音靠抑,去河邊找鬼。 笑死适掰,一個(gè)胖子當(dāng)著我的面吹牛颂碧,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播类浪,決...
    沈念sama閱讀 40,447評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼载城,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了费就?” 一聲冷哼從身側(cè)響起诉瓦,我...
    開封第一講書人閱讀 39,349評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后睬澡,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體固额,經(jīng)...
    沈念sama閱讀 45,820評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,990評(píng)論 3 337
  • 正文 我和宋清朗相戀三年煞聪,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了斗躏。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,127評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡昔脯,死狀恐怖啄糙,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情云稚,我是刑警寧澤隧饼,帶...
    沈念sama閱讀 35,812評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站碱鳞,受9級(jí)特大地震影響桑李,放射性物質(zhì)發(fā)生泄漏踱蛀。R本人自食惡果不足惜窿给,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,471評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望率拒。 院中可真熱鬧崩泡,春花似錦、人聲如沸猬膨。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,017評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽勃痴。三九已至谒所,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間沛申,已是汗流浹背劣领。 一陣腳步聲響...
    開封第一講書人閱讀 33,142評(píng)論 1 272
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留铁材,地道東北人尖淘。 一個(gè)月前我還...
    沈念sama閱讀 48,388評(píng)論 3 373
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像著觉,于是被迫代替她去往敵國(guó)和親村生。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,066評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 前言:Rxjava是通過觀察者模式設(shè)計(jì)的異步任務(wù)框架,他的有點(diǎn)在于簡(jiǎn)潔性,不是代碼的簡(jiǎn)潔性,而是邏輯的簡(jiǎn)潔性,隨著...
    松哦哦閱讀 4,342評(píng)論 2 1
  • 作者:IT魔幻師博客:www.huyingzi.top轉(zhuǎn)載請(qǐng)注明出處:https://www.jianshu.co...
    IT魔幻師閱讀 1,190評(píng)論 0 3
  • 用兩張圖告訴你饼丘,為什么你的 App 會(huì)卡頓? - Android - 掘金 Cover 有什么料趁桃? 從這篇文章中你...
    hw1212閱讀 12,732評(píng)論 2 59
  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,182評(píng)論 25 707
  • 昨天接待了一個(gè)女大學(xué)生卫病,近期被控制不住的身體傷害恐懼所困擾屡穗,總是害怕自己身體上的小傷口被感染,害怕自己身體生...
    夏禾平閱讀 207評(píng)論 0 3