Python Every Day, 第 2 天
python中的定義類方法有三種形式 普通方法 類方法(@classmethod)
靜態(tài)方法(@staticmethod)
1、普通方法的使用 class A(): def __init__(self, name, age): self.name = name self.age = age
def get_name(self): print('my name is', self.name)
def get_age(self): print(f'i am {self.age} years old')
class B(): def get_name(self, name): print('my name is', name)
def get_age(self, age): print(f'i am {age} years old')
if __name__ == '__main__': a = A('tom',19) a.get_name() # my name is tom a.get_age() # i am 19 years old
b = B() b.get_name('tom') # my name is tom b.get_age(19) # i am 19 years old
如上所示,創(chuàng)建普通的方法的方式有兩種(class A() & class B()). class A() 中, __init__()是一個特殊的方法,相當(dāng)于對A進(jìn)行初始化,__init__ 中的self是對象A本身,name和age是它們的形參。 每次調(diào)用方法之前需要對類進(jìn)行實(shí)例化, 例如 a = A('tom', 19) 2、類方法(@classmethod) 普通方法中,每次調(diào)用類中的方法,都需要先將類進(jìn)行實(shí)例化,相對比較麻煩。如果類中的函數(shù)前面加上@classmethod 或者 @staticmethod,則就不用再進(jìn)行實(shí)例化了。直接 類名.函數(shù)名 進(jìn)行調(diào)用 @classmethod不需要self來表示自身了,而是用了cls來代替。
示例如下: class C(): @classmethod def get_name(cls, name): print(cls) # <class '__main__.C'> print('my name is %s' % name)
@classmethod def get_age(cls, age): print(f'i am %s years old' % age)
if __name__ == '__main__': C.get_name('tom') # my name is tom C.get_age(19) # i am 19 years old
3、靜態(tài)方法(@staticmethod)
靜態(tài)方法也是通過 類名.函數(shù)名 的方式進(jìn)行調(diào)用,與類方法類似,不同的是,靜態(tài)方法不需要表示自身對象的self或者cls作為參數(shù),跟直接使用函數(shù)是一樣的。 class D(): @staticmethod def get_name(name): print('my name is %s' % name)
@staticmethod def get_age(age): print(f'i am %s years old' % age)
if __name__ == '__main__': D.get_name('tom') # my name is tom D.get_age(19) # i am 19 years old
總結(jié) @staticmethod 與 @classmethod在Python中稱為 裝飾器,用來修飾函數(shù),相當(dāng)于添加一個額外的功能,比如不再像普通函數(shù)那樣進(jìn)行實(shí)例化。通過使用裝飾器可以讓代碼更加整潔,易讀。用了修飾器之后,也可以進(jìn)行實(shí)例化之后再調(diào)用,但是就顯得多此一舉了。
| 普通方法 | 類方法(@classmethod) | 實(shí)例方法(@staticmethod) |
---|
a = A() | a.get_name() | a.get_name() | a.get_name() | A | 不可用 | A.get_name() | A.get_name() |
感謝您的閱讀
|