-----------------
閱讀代碼的時候,看到了classmethod。staticmethod用的挺多,classmethod一直沒用過,感覺有些迷惑。
Google了一篇文章,講的挺清楚:pyhton靜態方法和類方法。上面這篇文章主要講原理,我這里主要說說二者的相同和區別。
- 都可以通過類調用;
- 都可以通過對象調用;
- 都可以繼承和復寫;
- 都可以使用類屬性、類方法和類的靜態方法;
- 使用這些屬性或方法時,staticmethod必須直接通過類名進行調用,classmethod可以優雅的通過參數cls調用。
下面的代碼,簡單試驗了兩者的區別,并通過staticmethod簡單的模擬了classmethod的操作:
name = "Base"
@classmethod
def foo(cls):
print cls.name
@staticmethod
def foo_static1():
print Base.name
@staticmethod
def foo_static2(cls):
print cls.name
@staticmethod
def foo_static3(cls):
# if not isinstance(cls, type):
if isinstance(cls, Base):
cls = cls.__class__
print cls.name
class A(Base):
name = "A"
def __init__(self):
self.name = "I am '%s'" % A.name
class B(Base):
name = "B"
def __init__(self):
self.name = "I am '%s'" % B.name
@classmethod
def foo(cls):
print "<%s>" % cls.name
@staticmethod
def foo_static1():
print "<%s>" % Base.name
def testA():
obj = A()
obj.foo()
obj.foo_static1()
obj.foo_static2(A)
obj.foo_static2(obj)
obj.foo_static3(A)
obj.foo_static3(obj)
A.foo()
A.foo_static1()
def testB():
obj = B()
obj.foo()
obj.foo_static1()
def run_test(func, *args, **kwargs):
print "======================="
func(*args, **kwargs)
print ""
if __name__ == '__main__':
run_test(testA)
run_test(testB)
posted @ 2014-04-16 12:01 小夜 閱讀(410) | 評論 (0) | 編輯 收藏