python queue pip

1.Queue self._reader, self._writer = Pipe(duplex=False) 管道描述符 5/6 self._rlock = Lock() self._opid = os.getpid()

self._wlock = Lock()

输入图片说明

#coding:utf-8

from multiprocessing import Process, Queue import os, time, random

写数据进程执行的代码:

def write(q): for value in ['A', 'B', 'C']: print 'Put %s to queue...' % value q.put(value) time.sleep(random.random())

读数据进程执行的代码:

def read(q): while True: value = q.get(True) print 'Get %s from queue.' % 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()

========================= w:q.put() def put(self, obj, block=True, timeout=None)://obj是数据 assert not self._closed if not self._sem.acquire(block, timeout): raise Full

    self._notempty.acquire()
    try:
        if self._thread is None:
            self._start_thread()
        self._buffer.append(obj)//self._buffer.append拿到写者数据.
        self._notempty.notify()//通知读
    finally:
        self._notempty.release()

r: q.get() def get(self, block=True, timeout=None): if block and timeout is None: self._rlock.acquire()//管道可读 try: res = self._recv()// ‘A..‘读出数据 self._sem.release() return res finally: self._rlock.release()//释放’rlock‘

转载于:https://my.oschina.net/tplinuxhyh/blog/698271

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值