android - rxjava多線程并發怎么控制順序
問題描述
需求是從服務器獲取聊天列表,然后遍歷獲取聊天記錄,我這里用了Observable.from(conversations)然后對conversation插入本地數據庫,并且過濾得到需要的數據,最后更新view我看了一下午,這么多關鍵詞相關SerializedSubject(我用SerializedSubject.from(conversations)也不行,而轉類型Observable也報錯)trampoline(把任務放到當前線程的隊列中,等當前任務執行完了,再繼續執行隊列中的任務)concatEager(這個操作符跟concatMap有什么區別http://blog.csdn.net/kisty_ya... 但是使用上沒例子不太懂)剛開始是onNext里面處理下一步驟,然后我就用flatMap處理了,但是還是發射完成就結束了,沒有等onNext執行完,而且感覺doOnNext和flatMap是一樣的,希望能夠指點迷津,感覺像無頭蒼蠅一樣,能不能用偽代碼寫一下思路謝謝
問題解答
回答1:過濾的話應該用Filter這個操作符吧
回答2:用這個操作符concatMap可以保證線程執行的順序不會錯亂!
回答3:Obserable.fromCallable() .filter() .subscribe(io) .obserableOn(ui) .subscribe(action) 如果是需要將過濾的數據重新保存 Obserable data = Obserable.fromCallable() .filter() .subscribe(io) .share(); data.obserableon(io) .subscribe(數據庫) data.obserableOn(ui) .subscribe(更新)
相關文章:
1. 查詢mysql數據庫中指定表指定日期的數據?有詳細2. mysql - 怎么生成這個sql表?3. mysql - 數據庫建字段,默認值空和empty string有什么區別 1104. mysql - 數據庫表中,兩個表互為外鍵參考如何解決5. php - 公眾號文章底部的小程序二維碼如何統計?6. Navicat for mysql 中以json格式儲存的數據存在大量反斜杠,如何去除?7. sql語句 - 如何在mysql中批量添加用戶?8. mysql儲存json錯誤9. mysql - 表名稱前綴到底有啥用?10. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE語法實現存在即更新應該使用哪個標簽?
