詳解Python實(shí)現(xiàn)多進(jìn)程異步事件驅(qū)動(dòng)引擎
本文介紹了詳解Python實(shí)現(xiàn)多進(jìn)程異步事件驅(qū)動(dòng)引擎,分享給大家,具體如下:
多進(jìn)程異步事件驅(qū)動(dòng)邏輯
邏輯
code
# -*- coding: utf-8 -*- ''' author: Jimmy contact: 234390130@qq.com file: eventEngine.py time: 2017/8/25 上午10:06 description: 多進(jìn)程異步事件驅(qū)動(dòng)引擎 ''' __author__ = 'Jimmy' from multiprocessing import Process, Queue class EventEngine(object): # 初始化事件事件驅(qū)動(dòng)引擎 def __init__(self): #保存事件列表 self.__eventQueue = Queue() #引擎開關(guān) self.__active = False #事件處理字典{'event1': [handler1,handler2] , 'event2':[handler3, ...,handler4]} self.__handlers = {} #保存事件處理進(jìn)程池 self.__processPool = [] #事件引擎主進(jìn)程 self.__mainProcess = Process(target=self.__run) #執(zhí)行事件循環(huán) def __run(self): while self.__active: #事件隊(duì)列非空 if not self.__eventQueue.empty(): #獲取隊(duì)列中的事件 超時(shí)1秒 event = self.__eventQueue.get(block=True ,timeout=1) #執(zhí)行事件 self.__process(event) else: # print('無任何事件') pass #執(zhí)行事件 def __process(self, event): if event.type in self.__handlers: for handler in self.__handlers[event.type]: #開一個(gè)進(jìn)程去異步處理 p = Process(target=handler, args=(event, )) #保存到進(jìn)程池 self.__processPool.append(p) p.start() #開啟事件引擎 def start(self): self.__active = True self.__mainProcess.start() #暫停事件引擎 def stop(self): """停止""" # 將事件管理器設(shè)為停止 self.__active = False # 等待事件處理進(jìn)程退出 for p in self.__processPool: p.join() self.__mainProcess.join() #終止事件引擎 def terminate(self): self.__active = False #終止所有事件處理進(jìn)程 for p in self.__processPool: p.terminate() self.__mainProcess.join() #注冊(cè)事件 def register(self, type, handler): """注冊(cè)事件處理函數(shù)監(jiān)聽""" # 嘗試獲取該事件類型對(duì)應(yīng)的處理函數(shù)列表,若無則創(chuàng)建 try: handlerList = self.__handlers[type] except KeyError: handlerList = [] self.__handlers[type] = handlerList # 若要注冊(cè)的處理器不在該事件的處理器列表中,則注冊(cè)該事件 if handler not in handlerList: handlerList.append(handler) def unregister(self, type, handler): """注銷事件處理函數(shù)監(jiān)聽""" # 嘗試獲取該事件類型對(duì)應(yīng)的處理函數(shù)列表,若無則忽略該次注銷請(qǐng)求 try: handlerList = self.__handlers[type] # 如果該函數(shù)存在于列表中,則移除 if handler in handlerList: handlerList.remove(handler) # 如果函數(shù)列表為空,則從引擎中移除該事件類型 if not handlerList: del self.__handlers[type] except KeyError: pass def sendEvent(self, event): #發(fā)送事件 像隊(duì)列里存入事件 self.__eventQueue.put(event) class Event(object): #事件對(duì)象 def __init__(self, type =None): self.type = type self.dict = {} #測(cè)試 if __name__ == '__main__': import time EVENT_ARTICAL = "Event_Artical" # 事件源 公眾號(hào) class PublicAccounts: def __init__(self, eventManager): self.__eventManager = eventManager def writeNewArtical(self): # 事件對(duì)象,寫了新文章 event = Event(EVENT_ARTICAL) event.dict["artical"] = u'如何寫出更優(yōu)雅的代碼\n' # 發(fā)送事件 self.__eventManager.sendEvent(event) print(u'公眾號(hào)發(fā)送新文章\n') # 監(jiān)聽器 訂閱者 class ListenerTypeOne: def __init__(self, username): self.__username = username # 監(jiān)聽器的處理函數(shù) 讀文章 def ReadArtical(self, event): print(u'%s 收到新文章' % self.__username) print(u'%s 正在閱讀新文章內(nèi)容:%s' % (self.__username, event.dict["artical"])) class ListenerTypeTwo: def __init__(self, username): self.__username = username # 監(jiān)聽器的處理函數(shù) 讀文章 def ReadArtical(self, event): print(u'%s 收到新文章 睡3秒再看' % self.__username) time.sleep(3) print(u'%s 正在閱讀新文章內(nèi)容:%s' % (self.__username, event.dict["artical"])) def test(): listner1 = ListenerTypeOne("thinkroom") # 訂閱者1 listner2 = ListenerTypeTwo("steve") # 訂閱者2 ee = EventEngine() # 綁定事件和監(jiān)聽器響應(yīng)函數(shù)(新文章) ee.register(EVENT_ARTICAL, listner1.ReadArtical) ee.register(EVENT_ARTICAL, listner2.ReadArtical) for i in range(0, 20): listner3 = ListenerTypeOne("Jimmy") # 訂閱者X ee.register(EVENT_ARTICAL, listner3.ReadArtical) ee.start() #發(fā)送事件 publicAcc = PublicAccounts(ee) publicAcc.writeNewArtical() test()
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Python使用嵌套循環(huán)實(shí)現(xiàn)圖像處理算法
這篇文章主要給大家詳細(xì)介紹Python如何使用嵌套循環(huán)實(shí)現(xiàn)圖像處理算法,文中有詳細(xì)的代碼示例,具有一定的參考價(jià)值,需要的朋友可以參考下2023-07-07python cookie反爬處理的實(shí)現(xiàn)
這篇文章主要介紹了python cookie反爬處理的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11Python標(biāo)準(zhǔn)庫(kù)之多進(jìn)程(multiprocessing包)介紹
這篇文章主要介紹了Python標(biāo)準(zhǔn)庫(kù)之多進(jìn)程(multiprocessing包)介紹,本文講解了進(jìn)程池、共享資源、共享內(nèi)存、Manager等內(nèi)容,需要的朋友可以參考下2014-11-11Python3+OpenCV2實(shí)現(xiàn)圖像的幾何變換(平移、鏡像、縮放、旋轉(zhuǎn)、仿射)
這篇文章主要介紹了Python3+OpenCV2實(shí)現(xiàn)圖像的幾何變換(平移、鏡像、縮放、旋轉(zhuǎn)、仿射),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-05-05在Windows服務(wù)器下用Apache和mod_wsgi配置Python應(yīng)用的教程
這篇文章主要介紹了在Windows服務(wù)器下用Apache和mod_wsgi配置Python應(yīng)用的教程,本文選擇以flask框架作為示例,需要的朋友可以參考下2015-05-05基于Python制作一個(gè)端午節(jié)相關(guān)的小游戲
端午節(jié)快樂,今天我將為大家?guī)硪黄嘘P(guān)端午節(jié)的編程文章,希望能夠?yàn)榇蠹耀I(xiàn)上一份小小的驚喜,我們將會(huì)使用Python來實(shí)現(xiàn)一個(gè)與端午粽子相關(guān)的小應(yīng)用程序,在本文中,我將會(huì)介紹如何用Python代碼制做一個(gè)“粽子拆解器”,感興趣的小伙伴歡迎閱讀2023-06-06利用Python實(shí)現(xiàn)生成顏色表(color chart)
在做色彩相關(guān)的算法分析時(shí)候,經(jīng)常需要使用規(guī)則的顏色表來進(jìn)行輔助,本文就來利用numpy和opencv生成顏色表并保存為圖片,需要的可以參考一下2023-05-05python?Sweetviz探索性數(shù)據(jù)可視化分析庫(kù)使用特征詳解
這篇文章主要為大家介紹了python?Sweetviz探索性數(shù)據(jù)可視化分析庫(kù)特征使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2024-01-01