多进程_父进程子进程数据传递共享
admin
2023-07-14 03:44:13
0

进程queue传递
from multiprocessing import Process,Queue

def f(qq):
    qq.put([
42, None, 'hello'])

if __name__ == '__main__':
    q = Queue()
#父进程queue
   
p = Process(target=f,args=(q,)) #子进程 父进程的queue传给子进程 实现数据传递
   
p.start() #启动子进程
   
print(q.get())  # prints "[42, None, 'hello']" 父进程q可以get到子进程p 实现父进程子进程数据共享
   
p.join()

#线程queue不能传给进程

 
管道传递
from multiprocessing import Process, Pipe

def f(conn):
    conn.send([
42, None, 'hello from child'])
    conn.send([
43,None,'hello from child2'])
   
print("child recv:",conn.recv())
    conn.close()

if __name__ == '__main__':
    parent_conn, child_conn = Pipe() #生成管道实例,取出两端
    p = Process(
target=f, args=(child_conn,))
    p.start()
   
print(parent_conn.recv())# prints "[42, None, 'hello']"
   
print(parent_conn.recv())
    parent_conn.send(
"hello send by parent")
    p.join()



manager数据共享
from multiprocessing import Process, Manager
import os

def f(d, l):#每个子进程执行的函数
   
d[os.getpid()]=os.getpid()
    l.append(os.getpid())
   
print(l)


if __name__ == '__main__':
   
with Manager() as manager:#
       
d = manager.dict() #父进程生成一个字典 多个进程之间可共享的字典

       
l = manager.list(range(5)) #父进程生成一个列表 多个进程之间可以共享的列表 默认有5个数据
       
p_list = [] #用于多个进程join
       
for i in range(10):
            p = Process(
target=f, args=(d, l))
            p.start()
#开启10个子进程
           
p_list.append(p)
       
for res in p_list: # 等待每个子进程结果
           
res.join()

       
print(d)
       
print(l)

相关内容

热门资讯

问题居然在实体卡槽上!美版iP... 6月2日消息,日前,又有博主提前把还没发布的iPhone 18 Pro电池参数给曝光了出来,根据爆料...
2026年618手机购机攻略:... 每年618都是手机换新的最佳窗口期,2026年大促叠加数码国补、平台满减、品牌降价三重福利,新机老机...
8.99万打穿底价!史无前例的... 科技的浪漫,不是将人类送入遥不可及的星辰,而是把曾经高不可攀的科幻,变成柴米油盐里的“论斤卖”。 如...
苹果首款折叠屏iPhone U... PChome 6月2日消息,据知名数码博主@i冰宇宙最新曝光的机模谍照,苹果首款折叠屏手机(内部命名...
特朗普:美伊暂停谈判?假新闻! 当地时间6月2日,美国总统特朗普否认伊朗已停止与调解方沟通,称美国与伊朗之间的对话一直在持续进行。特...
白宫记协晚宴改期至7月,特朗普... 当地时间6月2日,美国总统特朗普表示,此前因突发暴力事件而中断的白宫记协晚宴已确定改期至7月24日举...
特朗普,开掉“不听话的情报头子... 苦撑15个月后,美国国家情报总监加巴德即将离开白宫。她对辞职的解释是:丈夫近期确诊罕见骨癌,自己希望...
面粉染头模仿黄仁勋,农村青年走... “先赔偿5000元肖像侵权使用费,再删除所有视频,要么就起诉你。”这是黄仁勋的模仿者杨洋最近频繁收到...
驻马店非遗“大集”开张 把网络... 顶端新闻记者 王丹/文 李思翰 胡楚昊/图红纸剪出“抵制网络谣言”,糖画写下“不信谣不传谣”……5月...
A股三大指数集体收涨 贵金属涨...   A股三大指数集体收涨 贵金属涨幅居前  【A股三大指数集体收涨 贵金属涨幅居前】6月2日,A股三...