對Python3之方法的覆蓋與super函式詳解

2022-09-28 10:09:14 字數 3203 閱讀 2867

#覆蓋

覆蓋:在繼承關係中,子類實現了與基類同名的方法,在子類的例項呼叫該方法時,例項呼叫的是子類的覆蓋版本。

通俗的講,就是小明繼承了他⑧的自行車,經過自己的改裝,成了電動車,那麼小明每次騎的就是電動車了(這個電動車是可以腳蹬的,後邊栗子會繼續使用)

舉個簡單的栗子:

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 ...