成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

響應式編程:集成到應用程序的步驟

譯文 精選
開發 前端
響應式編程是observables、observers和scheduler的結合。本文將和您探討響應式編程的術語,適用場景,以及如何將其代碼集成到應用中的基本步驟。

?譯者 | 陳峻

審校 | 孫淑娟

早在上世紀60年代, IT領域就首次出現了“響應式編程(reactive programming,Rx)”一詞。它在??維基百科中的定義??為:在計算機中,處理數據流和傳遞變更的一種聲明式編程方法。這種范式允許用戶輕松地指定靜態(如,數組)或動態(如,事件發射器)數據流,以及表明相關執行模型內部存在的、已推斷出的依賴關系,進而允許自動傳遞數據流的變更。在Rx編程中,各種數據流由同一個組件生成。各個Rx庫提供了底層的結構,并將這些變更傳遞給已注冊的、可接受此類數據變更的其他組件處。

關于響應式編程

總地說來,響應式編程是各種observable、observer和scheduler的結合。下面,我們將對這些術語進行深入解釋。

Observable

數據可以通過一個線程被傳輸到另一個線程,并存儲在observable中。簡單地說,observable是一種數據流。根據具體設置的不同,數據可以被定期發送,或者在其生命周期內僅發送一次。

一些操作符(operator)可以幫助observer(我們會在下一部分詳細介紹到)發出特定的數據,以響應各種事件。您可以暫且把observable視為提供者(supplier)。它們不但會處理數據,而且能夠將其發送到系統的其余部分。

Observers

Observer可以被理解為是消費者(consumer)。它們使用之前已注冊的observable,發送數據流。

Schedulers

簡而言之,在異步編程中,它們輕松地實現了線程管理。scheduler能夠指示observable和observer使用哪些線程。

什么時候適合使用響應式編程?

通常,我們在處理異步數據流時,響應式編程是一種流行的選擇。畢竟用例中的微小變化也可能成為我們決策的決定性因素。以下便是一些在現實世界中使用響應式編程的示例:

使用響應式編程開發移動應用程序

由于移動設備在性能上不足以處理繁重的任務,因此我們經常需要在執行期間或任務之后,根據后臺線程來更新主線程上的用戶界面。對此,我們需要在服務器上執行繁重的工作和復雜的計算。可見,對于此類網絡通訊活動的異步工作需求,響應式編程正好可以發揮作用。

在Netflix API中與RxJava一起使用響應式編程

為了減少網絡中的常規交互,我們需要使用RxJava服務器端的并發機制,在Netflix API中進行響應式編程。由于來自某個設備的每一個網絡請求,都會自動與其他網絡請求并行處理,因此如果服務器端無法支持并發執行的話,那么單個“重”的客戶端請求,很可能都不如幾個“輕”的客戶端請求的被處理速度。而且,即使我們已將網絡延遲考慮在內,如果一個已壓縮的“重”請求服務器端,在處理中沒有達到相同程度的并行處理,那么它就可能會比多個“輕”的請求要慢得多。

外部調用服務

由于如今許多后端服務都是RESTful類型(即,它們使用的是HTTP),因此底層協議可能會造成阻塞,以及出現同步調用外部服務的情況。在進行服務開發的時候,我們不但需要經常聯絡和調用其他的服務,而且要根據第一次調用的結果,按需調用額外更多的服務。因此,在面對眾多I/O時,我們需要在發出下一個請求之前,等待前一個調用的完成。而這往往會導致我們的客戶,因為喪失服務響應等待的耐心,而放棄后續的使用。

因此,我們有必要優化外部服務的調用,特別是那些針對跨不同調用之間復雜依賴關系的編排。響應式編程能夠保障此類活動的背后,在邏輯上的“可組合性”,以便調用服務的開發人員能夠更容易地編寫相關的代碼。

高并發消息的消費者

一種典型的企業用例往往發生在有大量并發消息處理的消費者處,尤其是在那些高度同步的情況下。而響應式框架的優勢就在于:通過測量微基準(microbenchmark),實現了每秒都能夠在JVM上處理大量的消息。

整合響應式編程

在線游戲、社交媒體和多人聊天室,都是持續使用音頻和視頻的應用程序(主要被用于流媒體)。而當涉及到特定類型的高負載、或多用戶應用時,響應式編程顯然是一個優雅的解決方案。不過,響應式技術的引入也可能會增加不必要的復雜性,甚至會給應用程序的性能帶來影響。因此,我們需要通過如下三個簡單步驟,合理地將響應式程序集成到目標應用中:

第1步:創建一個Data-Emitting類型的Observable

為了讓數據庫在Observable下,發送字符串型的數據。我們可以通過提供不同的參數,讓just()函數能夠逐一發送數據。

第2步:創建一個Data-Consuming類型的Observer

前續代碼片段中的observer能夠使用數據庫observable生成的數據。它不但可以接收數據,而且能夠處理數據,甚至還可以處理各種錯誤。

第3步:調節并發性

最后,我們來定義并發的scheduler。程序不但需要通過subscribeOn(Schedulers.newThread()),在后臺線程中告知數據庫observable去運行;而且需要通過observeOn(AndroidSchedulers.mainThread())在主線程上告知observer去運行。這便是最基本的響應式編程代碼。

總結

在上文中我們探討了響應模式的趨勢,以及如何將響應式編程集成到應用程序的步驟。就Java虛擬機而言,目前已有多個響應式代碼庫或框架正在被研發。它們不但功能全面,而且具有廣泛的兼容性。

譯者介紹

陳峻 (Julian Chen),51CTO社區編輯,具有十多年的IT項目實施經驗,善于對內外部資源與風險實施管控,專注傳播網絡與信息安全知識與經驗;持續以博文、專題和譯文等形式,分享前沿技術與新知;經常以線上、線下等方式,開展信息安全類培訓與授課。

原文標題:??Reactive Programming:The Steps To Integrate It Into Your Application???,作者:Gurpreet Singh?


責任編輯:華軒 來源: 51CTO
相關推薦

2022-06-16 13:08:30

Combine響應式編程訂閱

2021-04-30 16:54:27

分散式應用程序

2010-02-26 14:40:15

Python應用程序

2011-08-10 09:31:33

開發iPhone應用程

2012-11-01 11:34:31

IBMdw

2010-02-07 10:25:11

Android

2011-08-10 17:38:21

DB2JDBC

2012-10-29 09:40:24

云應用集成云計算管理IaaS

2021-08-30 20:19:55

應用程序

2009-07-03 06:57:32

2010-08-11 15:48:04

DB2編程

2010-08-11 15:48:04

DB2編程

2021-08-12 18:48:31

響應式編程Bio

2017-11-10 14:00:39

Riverbed應用程序網絡性能

2022-02-15 09:36:13

容器應用程序云服務

2009-06-01 11:37:46

EquinoxOSGi服務器

2009-07-29 17:42:47

ibmdwWeb2.0

2009-08-27 11:53:45

ibmdw云計算

2010-12-15 17:22:59

2025-05-06 01:14:00

系統編程響應式
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品久久精品 | 9色视频在线 | 精品在线一区二区 | 99久久国产免费 | 国产精品中文字幕在线 | 夜夜骑首页 | 免费成年网站 | 99精品视频网 | 日本精品久久久一区二区三区 | 欧美一区二区 | 亚洲天堂av网 | 欧美视频偷拍 | 国产四虎 | 欧美啪啪| 欧美 日本 国产 | 国产成人一区二区 | 成人在线免费视频 | 国产一区二区三区 | 精品一区二区三区在线观看国产 | 在线观看视频你懂得 | 国产九九九 | 91在线精品一区二区 | 国产1区在线 | 欧美成人一区二区三区 | 超碰520| 欧美a在线 | 99精品欧美一区二区蜜桃免费 | 欧美精品黄 | 精品一区二区三区在线视频 | 欧美日韩综合精品 | 秋霞电影一区二区 | 亚洲精品视频免费观看 | 天堂中文在线观看 | 日韩成人免费在线视频 | 成人美女免费网站视频 | 亚洲日本一区二区 | 久久久久国产一区二区三区四区 | 新av在线 | 欧美一级片久久 | 国产在线二区 | 91原创视频在线观看 |