python多进程系列(三)数据共享

一、进程中常用方法

1、p.start(): 当前进程准备就绪,等待被CPU调度(工作单元其实是进程中的线程)
2、p.join(): 等待当前进程的任务执行完成后再向下执行。
3、p.daemon=布尔值,守护进程(必须放在start之前)
p.daemon=True:设置为守护进程,主进程执行完毕,子进程也会自动关闭
p.daemon=False:设置为非守护进程,主进程等待子进程都执行完毕,主进程才结束
4、获取cpu核心数
count = multiprocessing.cpu_count()

二、队列共享数据

import multiprocessing
def demo(q):
    for i in range(8):
        #子进程往队列添加数据
        q.put(i)
if __name__ == '__main__':
    q = multiprocessing.Queue()
    p = multiprocessing.Process(target=demo,args=(q,))
    p.start()
    p.join()
    #主进程从队列拿出数据
    print(q.qsize()) #输出队列长度
    print(q.get())
    print(q.get())
    print(q.get())
    print(q.get())
    print(q.get())
    print(q.get())
    print(q.get())
    print(q.get())

三、管道共享数据

import time
import multiprocessing

def demo(conn):
    time.sleep(1)
    conn.send({"key1":"val1","key2":"val2"})
    # 从管道获取数据
    data = conn.recv()
    print("子进程接收到的数据:",data)
    time.sleep(1)

if __name__ == '__main__':
    #创建管道支持收发
    parent_conn,child_conn = multiprocessing.Pipe()
    p = multiprocessing.Process(target=demo,args=(child_conn,))
    p.start()
    #从管道获取数据
    msg = parent_conn.recv()
    print("主进程接收的数据:",msg)
    parent_conn.send(8888)
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值