#覆蓋
覆蓋:在繼承關係中,子類實現了與基類同名的方法,在子類的例項呼叫該方法時,例項呼叫的是子類的覆蓋版本。
通俗的講,就是小明繼承了他⑧的自行車,經過自己的改裝,成了電動車,那麼小明每次騎的就是電動車了(這個電動車是可以腳蹬的,後邊栗子會繼續使用)
舉個簡單的栗子:
clas 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().wohyivjasnahrk() # runtimeerror: super(): no arguments 不知道呼叫誰,所以此種省略引數的只能在內部使用
b.super_work() # 以上懂了,這回也就懂了
顯示呼叫基類的初始化方法:
當子類中實現了__init__(雙下劃線的init方法,貌似不顯示)方法,基類的構造方法並不會被呼叫,此時需要顯示呼叫
舉個栗子:
# 示意顯示呼叫初始化方法
class human:
def __init__(self, n, a):
self.name = n
self.age = a
print('hwww.cppcns.comuman初始化的方法被呼叫了')
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 = hyivjasnahname
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函式詳解
本文位址:
Python3解決棋盤覆蓋問題的方法示例
問題描述 在2 k 2 k個方格組成的棋盤中,有乙個方格被占用,用下圖的4種l型骨牌覆蓋所有棋盤上的其餘所有方格,不能重疊。如下 def chess tr,tc,pr,pc,size global mark global table mark 1 count mark if size 1 retur...
素數對猜想之python3實現
題目 讓我們定義d n 為 d n p n 1 p n 其中p i 是第i個素數。顯然有d 1 1,且對於n 1有d n 是偶數。素數對猜想 認為 存在無窮多對相鄰且差為2的素數 現給定任意正整數n 請計算不超過n的滿足猜想的素數對的個數。輸入在一行給出正整數n。在一行中輸出不超過n的滿足猜想的素數...
python返回方法 Python3之返回函式
python中函式不僅可以作為引數還可以作為結果返回 def pro1 c,f def pro2 return f c return pro2 呼叫函式pro1函式時,返回的是pro2函式物件 a pro1 3,abs a pro2 at 0x7fe07ed4eea0 需要對a呼叫才能得到結果 a ...