189 8069 5689

多进程_父进程子进程数据传递共享-创新互联

进程queue传递
frommultiprocessing importProcess,Queue

deff(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不能传给进程

目前创新互联公司已为1000多家的企业提供了网站建设、域名、网页空间、网站托管、服务器租用、企业网站设计、互助网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。
 
管道传递
frommultiprocessing importProcess, Pipe

deff(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数据共享
frommultiprocessing importProcess, Manager
importos

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


if__name__ == '__main__':
   withManager() asmanager:#
       
d = manager.dict() #父进程生成一个字典多个进程之间可共享的字典

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

       print(d)
       print(l)

另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


本文名称:多进程_父进程子进程数据传递共享-创新互联
分享网址:http://cdxtjz.com/article/ddojsh.html

其他资讯