如果在装饰器中无法使用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 (将#修改为@)