千锋教育-做有情怀、有良心、有品质的职业教育机构

手机站
千锋教育

千锋学习站 | 随时随地免费学

千锋教育

扫一扫进入千锋手机站

领取全套视频
千锋教育

关注千锋学习站小程序
随时随地免费学习课程

当前位置:首页  >  技术干货  > python进程之间如何通信

python进程之间如何通信

来源:千锋教育
发布人:xqq
时间: 2023-11-12 17:06:47 1699780007

python进程之间如何通信

本文教程操作环境:windows7系统、Python3.9.1,DELLG3电脑。

1、思路

Process之间肯定是需要通信的,操作系统提供了很多机制来实现进程间的通信。Python的multiprocessing模块包装了底层的机制,提供了Queue、Pipes等多种方式来交换数据。

2、实例

以Queue为例,在父进程中创建两个子进程,一个往Queue里写数据,一个从Queue里读数据。

frommultiprocessingimportProcess,Queue

importos,time,random

#写数据进程执行的代码:

defwrite(q):

print('Processtowrite:%s'%os.getpid())

forvaluein['A','B','C']:

print('Put%stoqueue...'%value)

q.put(value)

time.sleep(random.random())

#读数据进程执行的代码:

defread(q):

print('Processtoread:%s'%os.getpid())

whileTrue:

value=q.get(True)

print('Get%sfromqueue.'%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学习教程请关注IT培训机构:千锋教育。

tags: python培训
声明:本站稿件版权均属千锋教育所有,未经许可不得擅自转载。
10年以上业内强师集结,手把手带你蜕变精英
请您保持通讯畅通,专属学习老师24小时内将与您1V1沟通
免费领取
今日已有369人领取成功
刘同学 138****2860 刚刚成功领取
王同学 131****2015 刚刚成功领取
张同学 133****4652 刚刚成功领取
李同学 135****8607 刚刚成功领取
杨同学 132****5667 刚刚成功领取
岳同学 134****6652 刚刚成功领取
梁同学 157****2950 刚刚成功领取
刘同学 189****1015 刚刚成功领取
张同学 155****4678 刚刚成功领取
邹同学 139****2907 刚刚成功领取
董同学 138****2867 刚刚成功领取
周同学 136****3602 刚刚成功领取
相关推荐HOT