全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

详解Python实现多进程异步事件驱动引擎

本文介绍了详解Python实现多进程异步事件驱动引擎,分享给大家,具体如下:

多进程异步事件驱动逻辑

逻辑

code

# -*- coding: utf-8 -*-

'''
author:    Jimmy
contact:   234390130@qq.com
file:     eventEngine.py
time:     2017/8/25 上午10:06
description: 多进程异步事件驱动引擎

'''

__author__ = 'Jimmy'


from multiprocessing import Process, Queue


class EventEngine(object):
  # 初始化事件事件驱动引擎
  def __init__(self):
    #保存事件列表
    self.__eventQueue = Queue()
    #引擎开关
    self.__active = False
    #事件处理字典{'event1': [handler1,handler2] , 'event2':[handler3, ...,handler4]}
    self.__handlers = {}
    #保存事件处理进程池
    self.__processPool = []
    #事件引擎主进程
    self.__mainProcess = Process(target=self.__run)


  #执行事件循环
  def __run(self):
    while self.__active:
      #事件队列非空
      if not self.__eventQueue.empty():
        #获取队列中的事件 超时1秒
        event = self.__eventQueue.get(block=True ,timeout=1)
        #执行事件
        self.__process(event)
      else:
        # print('无任何事件')
        pass


  #执行事件
  def __process(self, event):
    if event.type in self.__handlers:
      for handler in self.__handlers[event.type]:
        #开一个进程去异步处理
        p = Process(target=handler, args=(event, ))
        #保存到进程池
        self.__processPool.append(p)
        p.start()


  #开启事件引擎
  def start(self):
    self.__active = True
    self.__mainProcess.start()


  #暂停事件引擎
  def stop(self):
    """停止"""
    # 将事件管理器设为停止
    self.__active = False
    # 等待事件处理进程退出
    for p in self.__processPool:
      p.join()
    self.__mainProcess.join()


  #终止事件引擎
  def terminate(self):
    self.__active = False
    #终止所有事件处理进程
    for p in self.__processPool:
      p.terminate()
    self.__mainProcess.join()


  #注册事件
  def register(self, type, handler):
    """注册事件处理函数监听"""
    # 尝试获取该事件类型对应的处理函数列表,若无则创建
    try:
      handlerList = self.__handlers[type]
    except KeyError:
      handlerList = []
      self.__handlers[type] = handlerList

    # 若要注册的处理器不在该事件的处理器列表中,则注册该事件
    if handler not in handlerList:
      handlerList.append(handler)


  def unregister(self, type, handler):
    """注销事件处理函数监听"""
    # 尝试获取该事件类型对应的处理函数列表,若无则忽略该次注销请求
    try:
      handlerList = self.__handlers[type]

      # 如果该函数存在于列表中,则移除
      if handler in handlerList:
        handlerList.remove(handler)

      # 如果函数列表为空,则从引擎中移除该事件类型
      if not handlerList:
        del self.__handlers[type]
    except KeyError:
      pass


  def sendEvent(self, event):
    #发送事件 像队列里存入事件
    self.__eventQueue.put(event)


class Event(object):
  #事件对象
  def __init__(self, type =None):
    self.type = type
    self.dict = {}



#测试
if __name__ == '__main__':
  import time
  EVENT_ARTICAL = "Event_Artical"

  # 事件源 公众号
  class PublicAccounts:
    def __init__(self, eventManager):
      self.__eventManager = eventManager

    def writeNewArtical(self):
      # 事件对象,写了新文章
      event = Event(EVENT_ARTICAL)
      event.dict["artical"] = u'如何写出更优雅的代码\n'
      # 发送事件
      self.__eventManager.sendEvent(event)
      print(u'公众号发送新文章\n')


  # 监听器 订阅者
  class ListenerTypeOne:
    def __init__(self, username):
      self.__username = username

    # 监听器的处理函数 读文章
    def ReadArtical(self, event):
      print(u'%s 收到新文章' % self.__username)
      print(u'%s 正在阅读新文章内容:%s' % (self.__username, event.dict["artical"]))


  class ListenerTypeTwo:
    def __init__(self, username):
      self.__username = username

    # 监听器的处理函数 读文章
    def ReadArtical(self, event):
      print(u'%s 收到新文章 睡3秒再看' % self.__username)
      time.sleep(3)
      print(u'%s 正在阅读新文章内容:%s' % (self.__username, event.dict["artical"]))


  def test():
    listner1 = ListenerTypeOne("thinkroom") # 订阅者1
    listner2 = ListenerTypeTwo("steve") # 订阅者2

    ee = EventEngine()

    # 绑定事件和监听器响应函数(新文章)
    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()

    #发送事件
    publicAcc = PublicAccounts(ee)
    publicAcc.writeNewArtical()

  test()

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# python  # 多进程事件驱动引擎  # 事件驱动引擎  # python事件驱动event实现详解  # wxPython事件驱动实例详解  # python实现事件驱动  # 若无  # 移除  # 列表中  # 设为  # 给大家  # 写了  # 管理器  # 再看  # 无任何  # 若要  # 绑定  # 大家多多  # 为空  # 出更  # 如何写  # 上午  # EventEngine  # Queue  # __processPool  # object 


相关文章: 公司网站制作费用多少,为公司建立一个网站需要哪些费用?  c++怎么用jemalloc c++替换默认内存分配器【性能】  淘宝制作网站有哪些,淘宝网官网主页?  建站之星代理如何优化在线客服效率?  免费的流程图制作网站有哪些,2025年教师初级职称申报网上流程?  如何规划企业建站流程的关键步骤?  建站之星代理平台如何选择最佳方案?  香港代理服务器配置指南:高匿IP选择、跨境加速与SEO优化技巧  如何在Tomcat中配置并部署网站项目?  建站之星伪静态规则如何设置?  javascript基本数据类型及类型检测常用方法小结  网站制作报价单模板图片,小松挖机官方网站报价?  高防服务器租用首荐平台,企业级优惠套餐快速部署  如何通过WDCP绑定主域名及创建子域名站点?  湖北网站制作公司有哪些,湖北清能集团官网?  上海网站制作网页,上海本地的生活网站有哪些?最好包括生活的各个方面的?  如何通过万网虚拟主机快速搭建网站?  如何选择高性价比服务器搭建个人网站?  南京做网站制作公司,南京哈发网络有限公司,公司怎么样,做网页美工DIV+CSS待遇怎么样?  山东云建站价格为何差异显著?  实现虚拟支付需哪些建站技术支撑?  如何用美橙互联一键搭建多站合一网站?  阿里云网站制作公司,阿里云快速搭建网站好用吗?  如何用PHP快速搭建CMS系统?  如何在云主机上快速搭建网站?  一键制作网站软件下载安装,一键自动采集网页文档制作步骤?  如何通过服务器快速搭建网站?完整步骤解析  Python如何创建带属性的XML节点  小程序网站制作需要准备什么资料,如何制作小程序?  C++如何将C风格字符串(char*)转换为std::string?(代码示例)  青浦网站制作公司有哪些,苹果官网发货地是哪里?  建站之星免费版是否永久可用?  详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)  免费网站制作模板下载,除了易企秀之外还有什么H5平台可以制作H5长页面,最好是免费的?  如何在Windows虚拟主机上快速搭建网站?  如何访问已购建站主机并解决登录问题?  香港服务器部署网站为何提示未备案?  南宁网站建设制作定制,南宁网站建设可以定制吗?  北京企业网站设计制作公司,北京铁路集团官方网站?  建站之星如何防范黑客攻击与数据泄露?  Java解压缩zip - 解压缩多个文件或文件夹实例  如何用狗爹虚拟主机快速搭建网站?  ,石家庄四十八中学官网?  手机网站制作与建设方案,手机网站如何建设?  合肥做个网站多少钱,合肥本地有没有比较靠谱的交友平台?  山东网站制作公司有哪些,山东大源集团官网?  如何挑选高效建站主机与优质域名?  义乌企业网站制作公司,请问义乌比较好的批发小商品的网站是什么?  如何快速辨别茅台真假?关键步骤解析  建站上传速度慢?如何优化加速网站加载效率? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。