码迷,mamicode.com
首页 > 编程语言 > 详细

python多线程执行类中的静态方法

时间:2018-01-27 13:35:34      阅读:156      评论:0      收藏:0      [点我收藏+]

标签:使用   函数   get   函数对象   ace   同步   def   pat   实现   

在python 中如果通过多线程的方式执行某个方法很简单,只需要把同步函数的第一个参数为该函数对象即可。但是如果函数对象是某个类的静态方法,这时候如果直接使用类的该函数对象会报错。此时需要构造一个代理的方法来实现。

如:上一个博文中的统计目录大小的静态类方法,如果想要查询多目录的空间大小,并且做成多线程个的方式。可采用下面的方法:

def dir_size_proxy(cls_instance, i):
    return cls_instance.get_dir_size(i)


class DiskSpaceUtil(object):
    @staticmethod
    def get_dir_list_size(dir_path_list):
        import multiprocessing
        pool = multiprocessing.Pool(processes=8)
        result_list = []
        for dir_path in dir_path_list:
            result_list.append(pool.apply_async(dir_size_proxy, (DiskSpaceUtil, dir_path)))
        pool.close()
        pool.join()

        size_list = [result.get() for result in result_list]
        return size_list

如图:

同步方法 DiskSpaceUtil 类中的 get_dir_size 方法。

代理函数: dir_size_proxy

 

python多线程执行类中的静态方法

标签:使用   函数   get   函数对象   ace   同步   def   pat   实现   

原文地址:https://www.cnblogs.com/dasheng-maritime/p/8365409.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!