python processpoolexecutor_ProcessPoolExecutor和Python中的锁定

我试图使用带锁的concurrent.futures.ProcessPoolExecutor,但我得到一个运行时错误.

(如果相关,我正在使用

Windows)

这是我的代码:

import multiprocessing

from concurrent.futures import ProcessPoolExecutor

import time

def f(i, lock):

with lock:

print(i, 'hello')

time.sleep(1)

print(i, 'world')

def main():

lock = multiprocessing.Lock()

pool = ProcessPoolExecutor()

futures = [pool.submit(f, num, lock) for num in range(3)]

for future in futures:

future.result()

if __name__ == '__main__':

main()

这是我得到的错误:

Traceback (most recent call last):

File "F:\WinPython-64bit-3.4.3.2\python-3.4.3.amd64\Lib\multiprocessing\queues.py", line 242, in _feed

obj = ForkingPickler.dumps(obj)

File "F:\WinPython-64bit-3.4.3.2\python-3.4.3.amd64\Lib\multiprocessing\reduction.py", line 50, in dumps

cls(buf, protocol).dump(obj)

File "F:\WinPython-64bit-3.4.3.2\python-3.4.3.amd64\Lib\multiprocessing\synchronize.py", line 102, in __getstate__

context.assert_spawning(self)

File "F:\WinPython-64bit-3.4.3.2\python-3.4.3.amd64\Lib\multiprocessing\context.py", line 347, in assert_spawning

' through inheritance' % type(obj).__name__

RuntimeError: Lock objects should only be shared between processes through inheritance

奇怪的是,如果我用multiprocessing.Process编写相同的代码,它一切正常:

import multiprocessing

import time

def f(i, lock):

with lock:

print(i, 'hello')

time.sleep(1)

print(i, 'world')

def main():

lock = multiprocessing.Lock()

processes = [multiprocessing.Process(target=f, args=(i, lock)) for i in range(3)]

for process in processes:

process.start()

for process in processes:

process.join()

if __name__ == '__main__':

main()

这有效,我得到:

1 hello

1 world

0 hello

0 world

2 hello

2 world

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值