python 多进程队列

1、多进程与多线程

python由于GIL全局解释锁,即使多cpu的机器下,一次也只能运行一个线程,所以CPU密集型的程序,要用多进程

2、队列

multiprocessing支持进程之间两种通信方式,队列Queue()和管道Pipe()

完美克隆Queue.Queue的功能

from multiprocessing import Process,Queue

def f(q):
    q.put(1)

if __name__ == "__main__":
    q=Queue()
    p = Process(target=f,args=(q,))
    p.start()
    print(q.get())
    p.join()

3、锁

lock=multiprocessing.Lock()

lock.acquire()获取锁

lock.release()释放锁

4、例子

import multiprocessing
import time
def worker(name,lock,q_res):
    lock.acquire()
    print("%s 1" % name)
    time.sleep(1)
    print("%s 2" % name)
    time.sleep(1)
    print("%s 3" % name)
    if not q_res.empty():
        print(q_res.get())
    lock.release()

if __name__=="__main__":
    pool = multiprocessing.Pool(4)
    m = multiprocessing.Manager()
    print(multiprocessing.cpu_count())
    p_lock = m.Lock()
    q_res = m.Queue()

    for i in range(2):
        q_res.put(i)
    for i in range(5):
        pool.apply_async(worker,args=("进程%d:" % i ,p_lock,q_res))
    pool.close()

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值