电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

淺談Python響應式類庫RxPy

瀏覽:4日期:2022-06-16 18:36:53
目錄一、基本概念1.1、Observable和Observer(可觀察對象和觀察者)1.2、Operator(操作符)1.3、Single(單例)1.4、Subject(主體)1.5、Scheduler(調度器)1.6、Observer和Observable1.7、操作符1.8、創建型操作符1.9、過濾型操作符1.10、轉換型操作符1.11、算術操作符1.12、Subject1.13、ReplaySubject1.14、BehaviorSubject1.15、AsyncSubject1.16、Scheduler二、應用場景2.1、防止重復發送2.2、操作數據流一、基本概念

Reactive X中有幾個核心的概念,先來簡單介紹一下。

1.1、Observable和Observer(可觀察對象和觀察者)

首先是Observable和Observer,它們分別是可觀察對象和觀察者。Observable可以理解為一個異步的數據源,會發送一系列的值。Observer則類似于消費者,需要先訂閱Observable,然后才可以接收到其發射的值。可以說這組概念是設計模式中的觀察者模式和生產者-消費者模式的綜合體。

1.2、Operator(操作符)

另外一個非常重要的概念就是操作符了。操作符作用于Observable的數據流上,可以對其施加各種各樣的操作。更重要的是,操作符還可以鏈式組合起來。這樣的鏈式函數調用不僅將數據和操作分隔開來,而且代碼更加清晰可讀。一旦熟練掌握之后,你就會愛上這種感覺的。

1.3、Single(單例)

在RxJava和其變體中,還有一個比較特殊的概念叫做Single,它是一種只會發射同一個值的Observable,說白了就是單例。當然如果你對Java等語言比較熟悉,那么單例想必也很熟悉。

1.4、Subject(主體)

主體這個概念非常特殊,它既是Observable又是Observer。正是因為這個特點,所以Subject可以訂閱其他Observable,也可以將發射對象給其他Observer。在某些場景中,Subject會有很大的作用。

1.5、Scheduler(調度器)

默認情況下Reactive X只運行在當前線程下,但是如果有需要的話,也可以用調度器來讓Reactive X運行在多線程環境下。有很多調度器和對應的操作符,可以處理多線程場景下的各種要求。

1.6、Observer和Observable

先來看看一個最簡單的例子,運行的結果會依次打印這些數字。這里的of是一個操作符,可以根據給定的參數創建一個新的Observable。創建之后,就可以訂閱Observable,三個回調方法在對應的時機執行。一旦Observer訂閱了Observable,就會接收到后續Observable發射的各項值。

from rx import ofob = of(1, 2, 34, 5, 6, 7, 7)ob.subscribe( on_next=lambda i: print(f’Received: {i}’), on_error=lambda e: print(f’Error: {e}’), on_completed=lambda: print(’Completed’))

這個例子看起來好像很簡單,并且看起來沒什么用。但是當你了解了Rx的一些核心概念,就會理解到這是一個多么強大的工具。更重要的是,Observable生成數據和訂閱的過程是異步的,如果你熟悉的話,就可以利用這個特性做很多事情。

1.7、操作符

在RxPy中另一個非常重要的概念就是操作符了,甚至可以說操作符就是最重要的一個概念了。幾乎所有的功能都可以通過組合各個操作符來實現。熟練掌握操作符就是學好RxPy的關鍵了。操作符之間也可以用pipe函數連接起來,構成復雜的操作鏈。

from rx import of, operators as opimport rxob = of(1, 2, 34, 5, 6, 7, 7)ob.pipe( op.map(lambda i: i ** 2), op.filter(lambda i: i >= 10)).subscribe(lambda i: print(f’Received: {i}’))

在RxPy中有大量操作符,可以完成各種各樣的功能。我們來簡單看看其中一些常用的操作符。如果你熟悉Java8的流類庫或者其他函數式編程類庫的話,應該對這些操作符感到非常親切。

1.8、創建型操作符

首先是創建Observable的操作符,列舉了一些比較常用的創建型操作符。

淺談Python響應式類庫RxPy

1.9、過濾型操作符

過濾型操作符的主要作用是對Observable進行篩選和過濾。

淺談Python響應式類庫RxPy

1.10、轉換型操作符

淺談Python響應式類庫RxPy

1.11、算術操作符

淺談Python響應式類庫RxPy

1.12、Subject

Subject是一種特殊的對象,它既是Observer又是Observable。不過這個對象一般不太常用,但是假如某些用途還是很有用的。所以還是要介紹一下。下面的代碼,因為訂閱的時候第一個值已經發射出去了,所以只會打印訂閱之后才發射的值。

from rx.subject import Subject, AsyncSubject, BehaviorSubject, ReplaySubject# Subject同時是Observer和Observableprint(’--------Subject---------’)subject = Subject()subject.on_next(1)subject.subscribe(lambda i: print(i))subject.on_next(2)subject.on_next(3)subject.on_next(4)subject.on_completed()# 2 3 4

另外還有幾個特殊的Subject,下面來介紹一下。

1.13、ReplaySubject

ReplaySubject是一個特殊的Subject,它會記錄所有發射過的值,不論什么時候訂閱的。所以它可以用來當做緩存來使用。ReplaySubject還可以接受一個bufferSize參數,指定可以緩存的最近數據數,默認情況下是全部。

下面的代碼和上面的代碼幾乎完全一樣,但是因為使用了ReplaySubject,所以所有的值都會被打印。當然大家也可以試試把訂閱語句放到其他位置,看看輸出是否會產生變化。

# ReplaySubject會緩存所有值,如果指定參數的話只會緩存最近的幾個值print(’--------ReplaySubject---------’)subject = ReplaySubject()subject.on_next(1)subject.subscribe(lambda i: print(i))subject.on_next(2)subject.on_next(3)subject.on_next(4)subject.on_completed()# 1 2 3 41.14、BehaviorSubject

BehaviorSubject是一個特殊的Subject,它只會記錄最近一次發射的值。而且在創建它的時候,必須指定一個初始值,所有訂閱它的對象都可以接收到這個初始值。當然如果訂閱的晚了,這個初始值同樣會被后面發射的值覆蓋,這一點要注意。

# BehaviorSubject會緩存上次發射的值,除非Observable已經關閉print(’--------BehaviorSubject---------’)subject = BehaviorSubject(0)subject.on_next(1)subject.on_next(2)subject.subscribe(lambda i: print(i))subject.on_next(3)subject.on_next(4)subject.on_completed()# 2 3 41.15、AsyncSubject

AsyncSubject是一個特殊的Subject,顧名思義它是一個異步的Subject,它只會在Observer完成的時候發射數據,而且只會發射最后一個數據。因此下面的代碼僅僅會輸出4.假如注釋掉最后一行co_completed調用,那么什么也不會輸出。

# AsyncSubject會緩存上次發射的值,而且僅會在Observable關閉后開始發射print(’--------AsyncSubject---------’)subject = AsyncSubject()subject.on_next(1)subject.on_next(2)subject.subscribe(lambda i: print(i))subject.on_next(3)subject.on_next(4)subject.on_completed()# 41.16、Scheduler

雖然RxPy算是異步的框架,但是其實它默認還是運行在單個線程之上的,因此如果使用了某些會阻礙線程運行的操作,那么程序就會卡死。當然針對這些情況,我們就可以使用其他的Scheduler來調度任務,保證程序能夠高效運行。

下面的例子創建了一個ThreadPoolScheduler,它是基于線程池的調度器。兩個Observable用subscribe_on方法指定了調度器,因此它們會使用不同的線程來工作。

import rxfrom rx.scheduler import ThreadPoolSchedulerfrom rx import operators as opimport multiprocessingimport timeimport threadingimport randomdef long_work(value): time.sleep(random.randint(5, 20) / 10) return valuepool_schedular = ThreadPoolScheduler(multiprocessing.cpu_count())rx.range(5).pipe( op.map(lambda i: long_work(i + 1)), op.subscribe_on(pool_schedular)).subscribe(lambda i: print(f’Work 1: {threading.current_thread().name}, {i}’))rx.of(1, 2, 3, 4, 5).pipe( op.map(lambda i: i * 2), op.subscribe_on(pool_schedular)).subscribe(lambda i: print(f’Work 2: {threading.current_thread().name}, {i}’))

如果你觀察過各個操作符的API的話,可以發現大部分操作符都支持可選的Scheduler參數,為操作符指定一個調度器。如果操作符上指定了調度器的話,會優先使用這個調度器;其次的話,會使用subscribe方法上指定的調度器;如果以上都沒有指定的話,就會使用默認的調度器。

二、應用場景

好了,介紹了一些Reactive X的知識之后,下面來看看如何來使用Reactive X。在很多應用場景下,都可以利用Reactive X來抽象數據處理,把概念簡單化。

2.1、防止重復發送

很多情況下我們都需要控制事件的發生間隔,比如有一個按鈕不小心按了好幾次,只希望第一次按鈕生效。這種情況下可以使用debounce操作符,它會過濾Observable,小于指定時間間隔的數據會被過濾掉。debounce操作符會等待一段時間,直到過了間隔時間,才會發射最后一次的數據。如果想要過濾后面的數據,發送第一次的數據,則要使用throttle_first操作符。

下面的代碼可以比較好的演示這個操作符,快速按回車鍵發送數據,注意觀察按鍵和數據顯示之間的關系,還可以把throttle_first操作符換成debounce操作符,然后再看看輸出會發生什么變化,還可以完全注釋掉pipe中的操作符,再看看輸出會有什么變化。

import rxfrom rx import operators as opfrom rx.subject import Subjectimport datetime# debounce操作符,僅在時間間隔之外的可以發射ob = Subject()ob.pipe( op.throttle_first(3) # op.debounce(3)).subscribe( on_next=lambda i: print(i), on_completed=lambda: print(’Completed’))print(’press enter to print, press other key to exit’)while True: s = input() if s == ’’:ob.on_next(datetime.datetime.now().time()) else:ob.on_completed()break2.2、操作數據流

如果需要對一些數據進行操作,那么同樣有一大堆操作符可以滿足需求。當然這部分功能并不是Reactive X獨有的,如果你對Java 8的流類庫有所了解,會發現這兩者這方面的功能幾乎是完全一樣的。

下面是個簡單的例子,將兩個數據源結合起來,然后找出來其中所有的偶數。

import rxfrom rx import operators as opfrom rx.subject import Subjectimport datetime# 操作數據流some_data = rx.of(1, 2, 3, 4, 5, 6, 7, 8)some_data2 = rx.from_iterable(range(10, 20))some_data.pipe( op.merge(some_data2), op.filter(lambda i: i % 2 == 0), # op.map(lambda i: i * 2)).subscribe(lambda i: print(i))

再或者一個利用reduce的簡單例子,求1-100的整數和。

import rxfrom rx import operators as opfrom rx.subject import Subjectimport datetimerx.range(1, 101).pipe( op.reduce(lambda acc, i: acc + i, 0)).subscribe(lambda i: print(i))

以上就是淺談Python響應式類庫RxPy的詳細內容,更多關于Python響應式類庫RxPy的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: ★济南领跃标识制作公司★济南标识制作,标牌制作,山东标识制作,济南标牌厂 | 希望影视-高清影视vip热播电影电视剧免费在线抢先看 | 气体热式流量计-定量控制流量计(空气流量计厂家)-湖北南控仪表科技有限公司 | 专注氟塑料泵_衬氟泵_磁力泵_卧龙泵阀_化工泵专业品牌 - 梭川泵阀 | 郑州大巴车出租|中巴车租赁|旅游大巴租车|包车|郑州旅游大巴车租赁有限公司 | 免费分销系统 — 分销商城系统_分销小程序开发 -【微商来】 | 沈飞防静电地板__机房地板-深圳市沈飞防静电设备有限公司 | 车牌识别道闸_停车场收费系统_人脸识别考勤机_速通门闸机_充电桩厂家_中全清茂官网 | 四探针电阻率测试仪-振实密度仪-粉末流动性测定仪-宁波瑞柯微智能 | 二手电脑回收_二手打印机回收_二手复印机回_硒鼓墨盒回收-广州益美二手电脑回收公司 | 拼装地板,悬浮地板厂家,悬浮式拼装运动地板-石家庄博超地板科技有限公司 | 报警器_家用防盗报警器_烟雾报警器_燃气报警器_防盗报警系统厂家-深圳市刻锐智能科技有限公司 | 假肢-假肢价格-假肢厂家-河南假肢-郑州市力康假肢矫形器有限公司 | 凝胶成像仪,化学发光凝胶成像系统,凝胶成像分析系统-上海培清科技有限公司 | 河南正规膏药生产厂家-膏药贴牌-膏药代加工-修康药业集团官网 | 医养体检包_公卫随访箱_慢病随访包_家签随访包_随访一体机-济南易享医疗科技有限公司 | 凝胶成像仪,化学发光凝胶成像系统,凝胶成像分析系统-上海培清科技有限公司 | 科普仪器菏泽市教育教学仪器总厂 | 焊锡丝|焊锡条|无铅锡条|无铅锡丝|无铅焊锡线|低温锡膏-深圳市川崎锡业科技有限公司 | 证券新闻,热播美式保罗1984第二部_腾讯1080p-仁爱影院 | 杭州代理记账多少钱-注册公司代办-公司注销流程及费用-杭州福道财务管理咨询有限公司 | 宁波普瑞思邻苯二甲酸盐检测仪,ROHS2.0检测设备,ROHS2.0测试仪厂家 | 电动液压篮球架_圆管地埋式篮球架_移动平箱篮球架-强森体育 | 电梯装饰-北京万达中意电梯装饰有限公司 | 苏州伊诺尔拆除公司_专业酒店厂房拆除_商场学校拆除_办公楼房屋拆除_家工装拆除拆旧 | CCC验厂-家用电器|服务器CCC认证咨询-奥测世纪 | 东莞工作服_东莞工作服定制_工衣订做_东莞厂服 | 直读光谱仪,光谱分析仪,手持式光谱仪,碳硫分析仪,创想仪器官网 | 英国雷迪地下管线探测仪-雷迪RD8100管线仪-多功能数字听漏仪-北京迪瑞进创科技有限公司 | 作文导航网_作文之家_满分作文_优秀作文_作文大全_作文素材_最新作文分享发布平台 | 哈尔滨治「失眠/抑郁/焦虑症/精神心理」专科医院排行榜-京科脑康免费咨询 一对一诊疗 | 物流之家新闻网-最新物流新闻|物流资讯|物流政策|物流网-匡匡奈斯物流科技 | 武汉森源蓝天环境科技工程有限公司-为环境污染治理提供协同解决方案 | 包塑丝_高铁绑丝_地暖绑丝_涂塑丝_塑料皮铁丝_河北创筹金属丝网制品有限公司 | 东莞韩创-专业绝缘骨架|马达塑胶零件|塑胶电机配件|塑封电机骨架厂家 | 定坤静电科技静电消除器厂家-除静电设备| 微妙网,专业的动画师、特效师、CG模型设计师网站! - wmiao.com 超声波电磁流量计-液位计-孔板流量计-料位计-江苏信仪自动化仪表有限公司 | 仓储笼_金属箱租赁_循环包装_铁网箱_蝴蝶笼租赁_酷龙仓储笼租赁 测试治具|过炉治具|过锡炉治具|工装夹具|测试夹具|允睿自动化设备 | ZHZ8耐压测试仪-上海胜绪电气有限公司| 【德信自动化】点胶机_全自动点胶机_自动点胶机厂家_塑料热压机_自动螺丝机-深圳市德信自动化设备有限公司 | 馋嘴餐饮网_餐饮加盟店火爆好项目_餐饮连锁品牌加盟指南创业平台 |