当前位置: 首页 > news >正文

Python并发执行(未完待续)

python的多进程执行

多进程实现方式一

from multiprocessing import Processdef func1(name):print("测试 %s 多进程" %name)if __name__ == "__main__":process_list = []for i in range(5):p = Process(target = func1, args = ('Python', ))p.start()process_list.append(p)for i in process_list:p.join()print("结束测试")

多进程实现方式二 

from multiprocessing import Processclass MyProcess(Process):   # 继承Process类def __init__(self, name):super(MyProcess, self).__init__()self.name = namedef run(self):print("测试%s多进程" % self.name)if __name__ == '__main__':process_list = []for i in range(5):p = MyProcess('Python {}'.format(i))p.start()process_list.append(p)for i in process_list:p.join()print('测试结束')

python进程通信方式

管道Pipe

调用Pipe()返回管道两端的Connection;Pipe的读写效率高于Queue,进程间的Pipe基于fork机制建立。

Python官方文档的描述:

Returns a pair (conn1, conn2) of Connection objects representing the ends of a pipe.

新建Pipe(duplex)的时候

  • 如何duplex为Flase,Pipe适用于只有两个进程一读一写的单双工情况; 
  • 如果duplex为True,Pipe适用于两个进程双工情况;【默认为True】

Pipe的方法包含 send()、recv()、close();当pipe的输入端被关闭,且无法接受接收到输入端的值,则会抛出EOFError。

from multiprocessing import Process, Pipe
import timedef func1(conn):print("子进程发送消息:")conn.send("你好主进程")print("子进程接收消息:")print(conn.recv())conn.close()if __name__ == '__main__':conn1, conn2 = Pipe()p = Process(target = func1, args = (conn2, ))p.start()time.sleep(1)print('主进程接受消息:')print(conn1.recv())print('主进程发送消息:')conn1.send("你好子进程")p.join()print('结束测试')
 进程队列

Queue是基于Pipe实现的

Queue的使用主要是一边put(),一边get();但是Queue可以是多个Process进行put操作,也可以是多个Process进行get操作。

from multiprocessing import Process, Queue
import timedef func1(queue, index):print("子进程 {} 开始put数据".format(index))queue.put("子进程 {}, 通过Queue开始通信".format(index))if __name__ == "__main__":queue = Queue()process_list = []for i in range(3):p = Process(target = func1, args = (queue, i, ))p.start()process_list.append(p)print("开始join")for i in process_list:p.join()print('主进程获取Queue数据')for i in range(3):print(queue.get())print("结束测试")

python的多线程执行

from concurrent.futures import ThreadPoolExecutor
import time# 设置最大的线程个数
executor = ThreadPoolExecutor(max_workers = 8)
all_num = 100def worker(index):time.sleep( (int)(index) / 5)print(index)def run():time1 = time.time()for id_ in range(all_num):executor.submit(worker,id_)executor.shutdown(wait = True)time2 = time.time()print(time2 - time1)if __name__ == "__main__":run()

http://www.lryc.cn/news/176197.html

相关文章:

  • 4.一元多项式相乘
  • Android Gilde获取网络图片显示保存路径并转化为bitmap
  • Uts阿里百川旗舰版插件UniApp-X
  • 一创聚宽的实盘就要关闭了,有没有好用的实盘平台推荐
  • 全套办公软件Office 2019 mac专业版功能
  • 【计算机网络】IP协议
  • 【操作系统笔记九】并发安全问题
  • 主要文库网站网赚分析
  • “ElementUI实现动态树和动态表格的综合应用“
  • 按键检测|中断检测
  • MySQL的执行流程
  • 如何办一份有价值的企业内刊/报纸?向《华为人》学习就够了
  • C++:从初识到初识的旅程
  • JavaWeb 学习
  • 百度SEO优化不稳定的原因分析(提升网站排名的稳定性)
  • 给你两个集合,要求{A} + {B}
  • Java获取实时摄像头进行拍照(附源码)
  • Kafka入门
  • 异地恋的甜蜜解药:李哥的群晖Videostation电影分享教程
  • JSON数据获取指南!
  • ASCII码-对照表
  • 点餐小程序的制作流程详解
  • Python应用程序:从Android日志到Excel文件的智能过滤和输出
  • C++常见面试题汇总
  • redis缓存穿透问题
  • 学生宿舍管理系统(前端java+后端Vue)实现-含前端与后端程序
  • codesys【网桥】
  • JS生成随机字符串的多种方法
  • 多维时序 | MATLAB实现GWO-BP多变量时间序列预测(灰狼算法优化BP神经网络)
  • PyTorch中的pyi檔案生成機制