Python中@staticmethod和@classmethod的作用和區別


Python有3種方法,靜態方法(staticmethod),類方法(classmethod)和實例方法。下面用代碼舉例。

對於一般的函數foo(x),它跟類和類的實例沒有任何關系,直接調用foo(x)即可。

# -*- coding:utf-8 -*-
def foo(x):
    print("running foo(%s)" % x)

foo("test")

在類A里面的實例方法foo(self, x),第一個參數是self,我們需要有一個A的實例,才可以調用這個函數。

# -*- coding:utf-8 -*-
class A:
    def foo(self, x):
        print("running foo(%s, %s)" % (self, x))

# A.foo(x) 這樣會報錯
a = A()
a.foo("test")

當我們需要和類直接進行交互,而不需要和實例進行交互時,類方法是最好的選擇。類方法與實例方法類似,但是傳遞的不是類的實例,而是類本身,第一個參數是cls我們可以用類的實例調用類方法,也可以直接用類名來調用。

# -*- coding:utf-8 -*-
class A:
    class_attr = "attr"
    
    def __init__(self):
        pass
        
    @classmethod
    def class_foo(cls):
        print("running class_foo(%s)" % (cls.class_attr))

a = A()
a.class_foo()
A.class_foo()

靜態方法類似普通方法,參數里面不用self。這些方法和類相關,但是又不需要類和實例中的任何信息、屬性等等。如果把這些方法寫到類外面,這樣就把和類相關的代碼分散到類外,使得之后對於代碼的理解和維護都是巨大的障礙。而靜態方法就是用來解決這一類問題的。

比如我們檢查是否開啟了日志功能,這個和類相關,但是跟類的屬性和實例都沒有關系。

# -*- coding:utf-8 -*-
log_enabled = True

class A:
    class_attr = "attr"
    
    def __init__(self):
        pass
        
    @staticmethod
    def static_foo():
        if log_enabled:
            print("log is enabled")
        else:
            print("log is disabled")
        

A.static_foo()

 

參考文章:

https://www.jianshu.com/p/ce117e8b1c61

https://blog.csdn.net/ljt735029684/article/details/80714274

https://github.com/jackfrued/interview_python


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM