侯体宗的博客
  • 首页
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

Python自定义进程池实例分析【生产者、消费者模型问题】

Python  /  管理员 发布于 7年前   258

本文实例分析了Python自定义进程池。分享给大家供大家参考,具体如下:

代码说明一切:

#encoding=utf-8#author: walker#date: 2014-05-21#function: 自定义进程池遍历目录下文件from multiprocessing import Process, Queue, Lockimport time, os#消费者class Consumer(Process):  def __init__(self, queue, ioLock):    super(Consumer, self).__init__()    self.queue = queue    self.ioLock = ioLock  def run(self):    while True:      task = self.queue.get()  #队列中无任务时,会阻塞进程      if isinstance(task, str) and task == 'quit':        break;      time.sleep(1)  #假定任务处理需要1秒钟      self.ioLock.acquire()      print( str(os.getpid()) + ' ' + task)      self.ioLock.release()    self.ioLock.acquire()    print 'Bye-bye'    self.ioLock.release()#生产者def Producer():  queue = Queue()  #这个队列是进程/线程安全的  ioLock = Lock()  subNum = 4  #子进程数量  workers = build_worker_pool(queue, ioLock, subNum)  start_time = time.time()  for parent, dirnames, filenames in os.walk(r'D:\test'):    for filename in filenames:      queue.put(filename)      ioLock.acquire()      print('qsize:' + str(queue.qsize()))      ioLock.release()      while queue.qsize() > subNum * 10: #控制队列中任务数量        time.sleep(1)  for worker in workers:    queue.put('quit')  for worker in workers:    worker.join()  ioLock.acquire()  print('Done! Time taken: {}'.format(time.time() - start_time))  ioLock.release()#创建进程池def build_worker_pool(queue, ioLock, size):  workers = []  for _ in range(size):    worker = Consumer(queue, ioLock)    worker.start()    workers.append(worker)  return workersif __name__ == '__main__':  Producer()

ps:

self.ioLock.acquire()...self.ioLock.release()

可用:

with self.ioLock:  ...

替代。

再来一个好玩的例子:

#encoding=utf-8#author: walker#date: 2016-01-06#function: 一个多进程的好玩例子import os, sys, timefrom multiprocessing import Poolcur_dir_fullpath = os.path.dirname(os.path.abspath(__file__))g_List = ['a']#修改全局变量g_Listdef ModifyDict_1():  global g_List  g_List.append('b')#修改全局变量g_Listdef ModifyDict_2():  global g_List  g_List.append('c')#处理一个def ProcOne(num):  print('ProcOne ' + str(num) + ', g_List:' + repr(g_List))#处理所有def ProcAll():  pool = Pool(processes = 4)  for i in range(1, 20):    #ProcOne(i)    #pool.apply(ProcOne, (i,))    pool.apply_async(ProcOne, (i,))  pool.close()  pool.join()ModifyDict_1() #修改全局变量g_Listif __name__ == '__main__':  ModifyDict_2() #修改全局变量g_List  print('In main g_List :' + repr(g_List))  ProcAll()

Windows7 下运行的结果:

λ python3 demo.pyIn main g_List :['a', 'b', 'c']ProcOne 1, g_List:['a', 'b']ProcOne 2, g_List:['a', 'b']ProcOne 3, g_List:['a', 'b']ProcOne 4, g_List:['a', 'b']ProcOne 5, g_List:['a', 'b']ProcOne 6, g_List:['a', 'b']ProcOne 7, g_List:['a', 'b']ProcOne 8, g_List:['a', 'b']ProcOne 9, g_List:['a', 'b']ProcOne 10, g_List:['a', 'b']ProcOne 11, g_List:['a', 'b']ProcOne 12, g_List:['a', 'b']ProcOne 13, g_List:['a', 'b']ProcOne 14, g_List:['a', 'b']ProcOne 15, g_List:['a', 'b']ProcOne 16, g_List:['a', 'b']ProcOne 17, g_List:['a', 'b']ProcOne 18, g_List:['a', 'b']ProcOne 19, g_List:['a', 'b']

Ubuntu 14.04下运行的结果:

In main g_List :['a', 'b', 'c']ProcOne 1, g_List:['a', 'b', 'c']ProcOne 2, g_List:['a', 'b', 'c']ProcOne 3, g_List:['a', 'b', 'c']ProcOne 5, g_List:['a', 'b', 'c']ProcOne 4, g_List:['a', 'b', 'c']ProcOne 8, g_List:['a', 'b', 'c']ProcOne 9, g_List:['a', 'b', 'c']ProcOne 7, g_List:['a', 'b', 'c']ProcOne 11, g_List:['a', 'b', 'c']ProcOne 6, g_List:['a', 'b', 'c']ProcOne 12, g_List:['a', 'b', 'c']ProcOne 13, g_List:['a', 'b', 'c']ProcOne 10, g_List:['a', 'b', 'c']ProcOne 14, g_List:['a', 'b', 'c']ProcOne 15, g_List:['a', 'b', 'c']ProcOne 16, g_List:['a', 'b', 'c']ProcOne 17, g_List:['a', 'b', 'c']ProcOne 18, g_List:['a', 'b', 'c']ProcOne 19, g_List:['a', 'b', 'c']

可以看见Windows7下第二次修改没有成功,而Ubuntu下修改成功了。据uliweb作者limodou讲,原因是Windows下是充重启实现的子进程;Linux下是fork实现的。

更多关于Python相关内容感兴趣的读者可查看本站专题:《Python URL操作技巧总结》、《Python图片操作技巧总结》、《Python数据结构与算法教程》、《Python Socket编程技巧总结》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》、《Python入门与进阶经典教程》及《Python文件与目录操作技巧汇总》

希望本文所述对大家Python程序设计有所帮助。


  • 上一条:
    Python实现更改图片尺寸大小的方法(基于Pillow包)
    下一条:
    python安装PIL模块时Unable to find vcvarsall.bat错误的解决方法
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 在python语言中Flask框架的学习及简单功能示例(0个评论)
    • 在Python语言中实现GUI全屏倒计时代码示例(0个评论)
    • Python + zipfile库实现zip文件解压自动化脚本示例(0个评论)
    • python爬虫BeautifulSoup快速抓取网站图片(1个评论)
    • vscode 配置 python3开发环境的方法(0个评论)
    • 近期文章
    • 在go语言中实现字符串可逆性压缩及解压缩功能(0个评论)
    • 使用go + gin + jwt + qrcode实现网站生成登录二维码在app中扫码登录功能(0个评论)
    • 在windows10中升级go版本至1.24后LiteIDE的Ctrl+左击无法跳转问题解决方案(0个评论)
    • 智能合约Solidity学习CryptoZombie第四课:僵尸作战系统(0个评论)
    • 智能合约Solidity学习CryptoZombie第三课:组建僵尸军队(高级Solidity理论)(0个评论)
    • 智能合约Solidity学习CryptoZombie第二课:让你的僵尸猎食(0个评论)
    • 智能合约Solidity学习CryptoZombie第一课:生成一只你的僵尸(0个评论)
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2018-04
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2022-01
    • 2023-07
    • 2023-10
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客