首頁 >後端開發 >Python教學 >基於python中staticmethod和classmethod的區別

基於python中staticmethod和classmethod的區別

不言
不言原創
2018-06-02 15:34:222068瀏覽

這篇文章主要介紹了關於基於python中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.foo(1)
# executing foo(<__main__.A object at 0xb7dbef0c>,1)

-----------------------------------------------------------------

a.class_foo(1)
# executing class_foo(<class &#39;__main__.A&#39;>,1)

A.class_foo(1)
# executing class_foo(<class &#39;__main__.A&#39;>,1)

-----------------------------------------------------------------

a.static_foo(1)
# executing static_foo(1)

A.static_foo(&#39;hi&#39;)
# executing static_foo(hi)

區別

• foo()的呼叫者必須是類別A的實例,class_foo()與static_foo()的呼叫者既可以是類別也可以是某個實例

• 參數不同,foo() 參數為self和其他參數,class_foo()參數使用類別(cls)替換了self,static_foo()則只有參數,沒有self和類別(cls)

• a.foo(1)中的foo()與a是綁定的,class_foo()是與類別綁定的,而static_foo()與a是綁定的,class_foo()是與類別綁定的,而static_foo()與這兩者都沒有綁定,可以使用print來查看,如下:

"
print(a.foo)
# <bound method A.foo of <main.A object at 0xb7d52f0c>>

print(a.class_foo)
# <bound method type.class_foo of <class &#39;main.A&#39;>>

print A.class_foo
<bound method classobj.class_foo of >

print(a.static_foo)
# 
print(A.static_foo)
# 
"

#• 使用場景:classmethod在一些工廠類別的情況下使用較多,也就是說OOP裡繼承的時候使用,staticmethod一般情況下可以替換為外部的函數,後者繼承的時候不可更改,和C /JAVA中的靜態方法很相似

• 有利於組織程式碼,同時有利於命名空間的整齊

## ##

以上是基於python中staticmethod和classmethod的區別的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn