python 類比事件觸發機制,python事件觸發機制

來源:互聯網
上載者:User

python 類比事件觸發機制,python事件觸發機制

EventManager.py

 1 # -*- encoding: UTF-8 -*- 2  3 # 系統模組 4 from queue import Queue, Empty 5 from threading import * 6  7  8 class EventManager: 9     def __init__(self):10         """初始化事件管理器"""11         # 事件對象列表12         self.__eventQueue = Queue()13         # 事件管理器開關14         self.__active = False15         # 事件處理線程16         self.__thread = Thread(target = self.__Run)17 18         # 這裡的__handlers是一個字典,用來儲存對應的事件的響應函數19         # 其中每個鍵對應的值是一個列表,列表中儲存了對該事件監聽的響應函數,一對多20         self.__handlers = {}   # {事件類型:[處理事件的方法]}21 22     def __Run(self):23         """引擎運行"""24         while self.__active == True:25             try:26                 # 擷取事件的阻塞時間設為1秒27                 event = self.__eventQueue.get(block = True, timeout = 1)  28                 self.__EventProcess(event)29             except Empty:30                 pass31 32     def __EventProcess(self, event):33         """處理事件"""34         # 檢查是否存在對該事件進行監聽的處理函數35         if event.type_ in self.__handlers:36             # 若存在,則按順序將事件傳遞給處理函數執行37             for handler in self.__handlers[event.type_]:38                 handler(event)39 40     def Start(self):41         """啟動"""42         # 將事件管理器設為啟動43         self.__active = True44         # 啟動事件處理線程45         self.__thread.start()46 47     def Stop(self):48         """停止"""49         # 將事件管理器設為停止50         self.__active = False51         # 等待事件處理線程退出52         self.__thread.join()53 54     def AddEventListener(self, type_, handler):55         """綁定事件和監聽器處理函數"""56         # 嘗試擷取該事件類型對應的處理函數列表,若無則建立57         try:58             handlerList = self.__handlers[type_]59         except KeyError:60             handlerList = []61 62         self.__handlers[type_] = handlerList63         # 若要註冊的處理器不在該事件的處理器列表中,則註冊該事件64         if handler not in handlerList:65             handlerList.append(handler)66 67     def RemoveEventListener(self, type_, handler):68         """移除監聽器的處理函數"""69         #讀者自己試著實現70 71     def SendEvent(self, event):72         """發送事件,向事件隊列中存入事件"""73         self.__eventQueue.put(event)74 75 """事件對象"""76 class Event:77     def __init__(self, type_=None):78         self.type_ = type_      # 事件類型79         self.dict = {}          # 字典用於儲存具體的事件數目據

test.py

 1 # -*- encoding: UTF-8 -*- 2  3 from threading import * 4 from EventManager import * 5 import time 6  7 #事件名稱  新文章 8 EVENT_ARTICAL = "Event_Artical" 9 10 11 #事件來源 公眾號12 class PublicAccounts:13     def __init__(self,eventManager):14         self.__eventManager = eventManager15 16     def WriteNewArtical(self):17         #事件對象,寫了新文章18         event = Event(type_=EVENT_ARTICAL)19         event.dict["artical"] = u'如何寫出更優雅的代碼\n'20         #發送事件21         self.__eventManager.SendEvent(event)22         print(u'公眾號發送新文章')23 24 25 #監聽器 訂閱者26 class Listener:27     def __init__(self,username):28         self.__username = username29 30     #監聽器的處理函數 讀文章31     def ReadArtical(self,event):32         print(u'%s 收到新文章' % self.__username)33         print(u'正在閱讀新文章內容:%s'  % event.dict["artical"])34 35 36 """測試函數"""37 def test():38     listner1 = Listener("thinkroom") #訂閱者139     listner2 = Listener("steve")#訂閱者240 41     eventManager = EventManager()42 43     #綁定事件和監聽器響應函數(新文章)44     eventManager.AddEventListener(EVENT_ARTICAL, listner1.ReadArtical)45     eventManager.AddEventListener(EVENT_ARTICAL, listner2.ReadArtical)46     eventManager.Start()47 48     publicAcc = PublicAccounts(eventManager)49     while True:50         publicAcc.WriteNewArtical()51         time.sleep(2)52 53 if __name__ == '__main__':54     test()

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.