
1. 類(lèi)的繼承與方法的重載


上面就是先定義了一個(gè)類(lèi)A,然后由定義了一個(gè)類(lèi)B,B繼承了類(lèi)A,這樣B就有了A的非私有屬性和方法。
class Washer: company='ZBL' def __init__(self,water=10,scour=2): self._water=water #不想讓用戶直接訪問(wèn)實(shí)例變量,可以標(biāo)志成私有 self.scour=scour self.year=2000#這是生產(chǎn)日期 #屬性包裝,將water屬性包裝成方法,用戶使用water時(shí)實(shí)際是訪問(wèn)的方法 @staticmethod #定義一個(gè)靜態(tài)方法 def spins_ml(spins): return spins*0.4 print('company:',Washer.company) #print('year:',self.year)#錯(cuò)誤,靜態(tài)方法不能使用實(shí)例屬性 @classmethod def get_washer(cls,water,scour):#cls相當(dāng)于實(shí)例方法中的self,調(diào)用是不用提供這個(gè)參數(shù) return cls(water,cls.spins_ml(scour))#cls代表類(lèi)名Washer,故不是硬編碼(改類(lèi)名是不用改cls,若cls用類(lèi)名代替也對(duì),但若改類(lèi)名這個(gè)地方也需要改動(dòng)) @property def water1(self):#如果用戶使用 實(shí)例.water相當(dāng)于訪問(wèn)這個(gè)方法,而不是真的訪問(wèn)屬性 return self._water @water1.setter def water1(self,water): if 0<water<=500: self._water=water else: print('set Failure!') @property def total_year(self): return 2017-self.year def set_water(self,water): self.water=water def set_scour(self,scour): self.scour=scour def add_water(self): print('Add water:',self._water) def add_scour(self): print('Add scour:',self.scour) def start_wash(self): self.add_water() self.add_scour() print('Start wash...') class WasherDry(Washer):# 建立一個(gè)新類(lèi),繼承自Washer def dry(self):#新類(lèi)中可以定義只屬于子類(lèi)的新方法 print('Dry cloths...') def start_wash(self):#在子類(lèi)中新定義與父類(lèi)同名的方法就是方法的重載 self.add_scour() self.add_water() if __name__=='__main__':## print(Washer.spins_ml (8))## w=Washer()## print(w.spins_ml(8))## w=Washer(200,Washer.spins_ml(8))## w.start_wash() w=WasherDry() w.start_wash() print(w.scour,w.company) w.dry()以上這篇python面向?qū)ο骭詳談?lì)惖睦^承與方法的重載就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持武林網(wǎng)。
新聞熱點(diǎn)
疑難解答
圖片精選