您好,登錄后才能下訂單哦!
#覆蓋
覆蓋:在繼承關系中,子類實現了與基類同名的方法,在子類的實例調用該方法時,實例調用的是子類的覆蓋版本。
通俗的講,就是小明繼承了他⑧的自行車,經過自己的改裝,成了電動車,那么小明每次騎的就是電動車了(這個電動車是可以腳蹬的,后邊栗子會繼續使用)
舉個簡單的栗子:
class Bicycle(): def run(self): print('我是自行車的run方法') class E_Bicycle(Bicycle): # 繼承自行車 def run(self): print('我是電動車的run方法') b = Bicycle() b.run() e_b = E_Bicycle() e_b.run()
打印結果:
我是自行車的run方法 我是電動車的run方法
注意:方法的覆蓋必須要同名,例如這個栗子是繼承與派生關系,方法還同名,只是print被改變了
這個栗子不是特別明顯,改動一點點:
class Bicycle(object): def __init__(self, name): self.name = name def run(self): print('我是%s的run方法'%self.name) class E_Bicycle(Bicycle): # 繼承自行車 def __init__(self, name, age): self.name = name self.age = age def run(self): print('我是%s的run方法, 被主人改裝%s年了'%(self.name, self.age)) b = Bicycle('自行車') b.run() e_b = E_Bicycle('電動車', 3) e_b.run()
改變了name值,并且加入了age參數。
那么如何調用父類的方法呢或屬性呢?
#super
super(cls, obj)返回綁定超類的實例(要去obj必須是cls類型的實例)
super的作用:間接調用父類覆蓋方法
舉個栗子:
# 示意super函數間接調用父類中被覆蓋的方法 class A: def work(self): print('A.work被調用') class B(A): '''B類繼承A類''' def work(self): print('B.work被調用') def super_work(self): '''調用B類自己的work方法''' self.work() # B.work被調用,調用自身類的方法,和調用屬性一樣 super(B, self).work() # A.work被調用, 借助super調用父類被覆蓋的方法 super().work() # A.work被調用 這種必須在方法內使用 ,可以省略(自身類)參數 b = B() # b.work() # B.work被調用,調自身的類 # super(B, b).work() # A.work被調用(使用super是調用B的父類) # super().work() # RuntimeError: super(): no arguments 不知道調用誰,所以此種省略參數的只能在內部使用 b.super_work() # 以上懂了,這回也就懂了
顯示調用基類的初始化方法:
當子類中實現了__init__(雙下劃線的init方法,貌似不顯示)方法,基類的構造方法并不會被調用,此時需要顯示調用
舉個栗子:
# 示意顯示調用初始化方法 class Human: def __init__(self, n, a): self.name = n self.age = a print('Human初始化的方法被調用了') def infos(self): print('姓名', self.name) print('年齡', self.age) class Student(Human): def __init__(self, n, a, s=0): # super(Student, self).__init__(n, a) # 調用父類的初始化方法 復習上邊講的 super().__init__(n, a) # 調用父類的初始化方法 內部省略參數 self.score = s # 增加一個屬性 print('Student的初始化方法被調用了') def infos(self): # 方法的重寫 super().infos() # 顯示調用父類的方法 print('成績是:', self.score) s1 = Student('張三', 20, 80) s1.infos()
打印結果:
Human初始化的方法被調用了 Student的初始化方法被調用了 姓名 張三 年齡 20 成績是: 80
改寫上述的自行車與電動車的栗子:
class Bicycle(object): def __init__(self, name): self.name = name def run(self): print('我是%s的run方法'%self.name) class E_Bicycle(Bicycle): # 繼承自行車 def __init__(self, name, age): super().__init__(name) # 調用父類的name屬性 self.age = age def run(self): super().run() # 調用父類的run方法 print('被主人改裝%s年了'%(self.age) b = Bicycle() b.run() e_b = E_Bicycle('電動車', 3) e_b.run()
本節就到這吧
以上這篇對Python3之方法的覆蓋與super函數詳解就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。