[PYTHON]MultiProcess多进程使用

MultiProcess多进程使用:
直接import和调用python的multiprocess库(分别使用Pool和Process来启动和管理多进程);
方法:
1.类库:

import abc 
import multiprocessing 
import queue 

class IExecutor(object): 
    def __init__(self): 
        pass 

    @abc.abstractmethod 
    def init(self, info): 
        pass 

    @abc.abstractmethod 
    def execute_task(self, func, args): 
    """ 执行任务 """ 
        pass 

    @abc.abstractmethod 
    def execute_multi_task(self, func, args): 
        """ 执行任务 """ 
        pass 

    @abc.abstractmethod 
    def join(self): 
        pass 

class ProcessPool(IExecutor): 
    """ Processes Pool """ 
    def __init__(self): 
        IExecutor.__init__(self) 
        self.__pool = None 

    def init(self): 
        if self.__pool: 
            self.join() 

        self.__pool = multiprocessing.Pool() 

    def execute_task(self, func, args): 
        return self.__pool.apply(func = func, args = args) 

    def join(self): 
        self.__pool.close() 
        self.__pool.join() 

    def __getstate__(self): 
        self_dict = self.__dict__.copy() 
        del self_dict['__pool'] 
        return self_dict 

    def __setstate__(self, state): 
        self.__dict__.update(state) 

class MultiProcesses(IExecutor): 
    """ Processes """ 
    def __init__(self): 
        IExecutor.__init__(self) 
        self.__processes = [] 
        self.__count = min(multiprocessing.cpu_count(), MAX_PROCESSOR_NUM) 

    def init(self):
        if len(self.__processes): 
            self.join() 

    def execute_multi_task(self, func, args): 
        for i in range(self.__count): 
            t = multiprocessing.Process(target = func, args = args) 
            t.start() 
            self.__processes.append(t) 

    def execute_task(self, func, args): 
        t = multiprocessing.Process(target = func, args = args) 
        t.start() 
        self.__processes.append(t) 

    def join(self): 
        for t in self.__processes: 
            t.join() 
            self.__processes = [] 

2.使用

executor = MultiProcesses()
executor.init()
executor.execute_multi_task(func, (arg1, arg2, arg3, ))

说明:

  • python要使用多核心计算资源可以通过多进程来实现,一般进程数量和cpu核心数量相关;
  • python多进程对性能的提升有极限,如果对性能要求极高,可以尝试用python调用c接口的方式实现;
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值