python 队列与列表_使用队列列表的Python多处理

在父级中创建Queue的列表,在创建时向每个工作线程传递一些。每个工作线程将从其一个队列获取作业,然后输出到另一个队列。在import logging, multiprocessing

def myproc(arg):

return arg*2

def worker(qlist):

logger = multiprocessing.get_logger()

logger.info('start')

while True:

job = qlist[0].get()

logger.info('got %s', job)

if job is None:

logger.info('exiting')

return

qlist[1].put( myproc(job) )

logger = multiprocessing.log_to_stderr(

level=logging.INFO,

)

logger.info('setup')

numProcs = 3

queueList = [ multiprocessing.Queue() for i in xrange(numProcs) ]

# prefill with 3 jobs

for num in range(3):

queueList[0].put(num)

# signal end of jobs

queueList[0].put(None)

worker_p = multiprocessing.Process(

target=worker, args=( [queueList[0], queueList[1]], ),

name='worker',

)

worker_p.start()

worker_p.join()

logger.info('done')

示例运行:

^{2}$

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值