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

我尝试使用Python 2.7多处理包创建队列列表.每个子进程拥有一个单独的队列,并有两个任务:从自己的队列中获取元素并将元素放到其他子进程的队列中.因此,每个子进程必须知道哪个队列属于它,这就是我使用队列列表的原因.

我的代码如下:

mgr = multiprocessing.Manager()

sharedQueueList = mgr.list()

for i in xrange(num_processes):

sharedQueueList .append(mgr.Queue())

但是,我收到以下错误消息:

**raise convert_to_error(kind, result)**

RemoteError:

---------------------------------------------------------------------------

Unserializable message: ('#RETURN', < Queue.Queue instance at 0x02AD3170 >)

---------------------------------------------------------------------------

解决方法:

在父项中创建队列列表,在创建时为每个员工提供一些队列.每个工作人员将从其中一个队列中获取作业,并输出到另一个队列.

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')

示例运行:

[INFO/MainProcess] setup

[INFO/worker] child process calling self.run()

[INFO/worker] start

[INFO/worker] got 0

[INFO/worker] got 1

[INFO/worker] got 2

[INFO/worker] got None

[INFO/worker] exiting

[INFO/worker] process shutting down

[INFO/worker] process exiting with exitcode 0

[INFO/MainProcess] done

[INFO/MainProcess] process shutting down

标签:python,serialization,multithreading,queue,list

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值