詳解Python中@staticmethod和@classmethod區別及使用示例代碼
本文主要介紹Python中,class(類)的裝飾器@staticmethod和@classmethod的使用示例代碼和它們的區別。
1、@staticmethod和@classmethod區別@staticmethod:靜態方法
@classmethod:類方法
一般來說,要使用某個類的方法,需要先實例化一個對象再調用方法。
而使用@staticmethod或@classmethod,就可以不需要實例化,直接通過類名就可以實現調用
使用:直接類名.方法名()來調用。@staticmethod和@classmethod都可以直接類名.方法名()來調用,
@staticmethod不需要表示自身對象的self和自身類的cls參數(這兩個參數都不需要添加),就跟使用函數一樣。
使用:直接類名.屬性名或直接類名.方法名。
@classmethod也不需要self參數,但第一個參數需要是表示自身類的cls參數。
使用:直接類名.屬性名或直接類名.方法名。
兩者定義的裝飾器調用方法一樣,但是@classmethod裝飾器定義的類方法需要傳入類參數cls。
@staticmethod中要調用到這個類的一些屬性方法,只能直接類名.屬性名或類名.方法名。
而@classmethod有cls參數,可以來調用類的屬性,類的方法,實例化對象等,避免硬編碼更靈活。
2、@staticmethod和@classmethod使用示例代碼class A(object): def foo(self, x): print 'executing foo(%s, %s)' % (self, x) @classmethod def class_foo(cls, x): print 'executing class_foo(%s, %s)' % (cls, x) @staticmethod def static_foo(x): print 'executing static_foo(%s)' % x a = A()#通過實例調用方法,對象實例a作為第一個參數隱式傳遞。a.foo (1)# executing foo(<__main__.A object at 0xb7dbef0c>,1)#對于類方法,對象實例的類將隱式地作為第一個參數而不是傳遞selfa.class_foo(1)# executing class_foo(<class ’__main__.A’>,1)#使用這個類調用class_fooA.class_foo(1)# executing class_foo(<class ’__main__.A’>,1)#對于staticmethods,self(對象實例)和cls(類)都不會作為第一個參數隱式傳遞。它們的行為類似普通函數,除了你可以從實例或類中調用它們a.static_foo(1)# executing static_foo(1)A.static_foo(’hi’)# executing static_foo(hi)print(a.foo)# <bound method A.foo of <__main__.A object at 0xb7d52f0c>>print(a.class_foo)# <bound method type.class_foo of <class ’__main__.A’>>print(a.static_foo)# <function static_foo at 0xb7d479cc>print(a.static_foo)# <function static_foo at 0xb7d479cc>
總結一下彼此的調用區別:
到此這篇關于詳解Python中@staticmethod和@classmethod區別及使用示例代碼的文章就介紹到這了,更多相關Python @staticmethod和@classmethod內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!
相關文章:
