如何解决如果在装饰器中无法使用ProcessPoolExecutor?
我有一个简单的例子:
from functools import wraps
from concurrent import futures
import random
def decorator(func):
num_process = 4
def impl(*args,**kwargs):
with futures.ProcessPoolExecutor() as executor:
fs = []
for i in range(num_process):
fut = executor.submit(func,*args,**kwargs)
fs.append(fut)
result = []
for f in futures.as_completed(fs):
result.append(f.result())
return result
return impl
@decorator
def get_random_int():
return random.randint(0,100)
if __name__ == "__main__":
result = get_random_int()
print(result)
如果我们尝试运行此功能,我认为我们将出现以下错误:
_pickle.PicklingError: Can't pickle <function get_random_int at 0x7f06cee666a8>: it's not the same object as __main__.get_random_int
我认为这里的主要问题是“ wraps”装饰器本身会更改func
对象,因此无法进行腌制。我发现这很奇怪。我只是想知道是否有任何方法可以解决此问题?如果可能的话,我想使用wraps
。谢谢!
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。