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