zoukankan      html  css  js  c++  java
  • python多线程执行类中的静态方法

    在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

  • 相关阅读:
    JavaScript ECMAScript版本介绍
    Webpack
    路由
    组件(重难点)
    npm包管理工具
    过滤器
    Vue实例生命周期
    数据双向绑定的原理
    MVC + MVVM
    vue事件修饰符
  • 原文地址:https://www.cnblogs.com/dasheng-maritime/p/8365409.html
Copyright © 2011-2022 走看看