您现在的位置是:课程教程文章
python进程之间如何通信
2023-12-14 22:08课程教程文章 人已围观
-
软件测试编程语言学习(10):Python入门之异
软件测试编程语言学习(10):Python入门之异... -
Python自动化/unittest框架/单元测试/自动化
Python自动化/unittest框架/单元测试/自动化1、Selenium操作百度浏览器并截图 2、UnitTest框架基本使用 3、Unittest进阶测试套件... -
【誉天】Python爬虫高手加薪系列
【誉天】Python爬虫高手加薪系列恭喜 聪明又睿智 的你~ 加入咱们的誉天大家庭一起学习! 请加咱们可爱的小鹿... -
Python界面编程 PyQt5 GUI开发基础与实战
Python界面编程 PyQt5 GUI开发基础与实战...
本文教程操作环境:windows7系统、Python 3.9.1,DELL G3电脑。
1、思路
Process之间肯定是需要通信的,操作系统提供了很多机制来实现进程间的通信。Python的multiprocessing模块包装了底层的机制,提供了Queue、Pipes等多种方式来交换数据。
2、实例
以Queue为例,在父进程中创建两个子进程,一个往Queue里写数据,一个从Queue里读数据。
from multiprocessing import Process, Queue import os, time, random # 写数据进程执行的代码: def write(q): print('Process to write: %s' % os.getpid()) for value in ['A', 'B', 'C']: print('Put %s to queue...' % value) q.put(value) time.sleep(random.random()) # 读数据进程执行的代码: def read(q): print('Process to read: %s' % os.getpid()) while True: value = q.get(True) print('Get %s from queue.' % value) if __name__=='__main__': # 父进程创建Queue,并传给各个子进程: q = Queue() pw = Process(target=write, args=(q,)) pr = Process(target=read, args=(q,)) # 启动子进程pw,写入: pw.start() # 启动子进程pr,读取: pr.start() # 等待pw结束: pw.join() # pr进程里是死循环,无法等待其结束,只能强行终止: pr.terminate()
以上就是python进程之间通信的方法,希望能对大家有所帮助。更多Python学习指路:python基础教程
课程教程:python进程之间如何通信上一篇:python中insort的使用
下一篇:没有了