溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

python3的多繼承問題

發(fā)布時(shí)間:2020-06-19 04:21:05 來源:網(wǎng)絡(luò) 閱讀:519 作者:wx5a4c600866558 欄目:編程語言

#在Python的多繼承中,如果子類繼承的多個(gè)父類中包含了同名的方法,子類在調(diào)用時(shí)會(huì)選擇哪個(gè)

class Item :
    def info (self):
        print("Item中的方法","這是一個(gè)商品")

class Product:
    def info(self):
        print("Product中的方法" , "這是一個(gè)工業(yè)產(chǎn)品")

class Mouse(Item, Product):
    pass

m = Mouse()
m.info()

輸出:
Item中的方法,這是一個(gè)商品

class Item :
    def info (self):
        print("Item中的方法","這是一個(gè)商品")

class Product:
    def info(self):
        print("Product中的方法" , "這是一個(gè)工業(yè)產(chǎn)品")

class Mouse(Product, Item):
    pass

m = Mouse()
m.info()

輸出:
Product中的方法 這是一個(gè)工業(yè)產(chǎn)品
總結(jié):
可見多繼承中,父類有同名方法,子類在調(diào)用時(shí)會(huì)選擇繼承中排在前面的父類方法
拓展:
如果子類也包含同名方法,子類調(diào)用同名方法,優(yōu)先選擇自己的方法,這叫做重寫,也叫覆蓋override

class Item :
    def info (self):
        print("Item中的方法","這是一個(gè)商品")

class Product:
    def info(self):
        print("Product中的方法" , "這是一個(gè)工業(yè)產(chǎn)品")

class Mouse(Item, Product):
    def info(self):
        print("這是一個(gè)鼠標(biāo)")

m = Mouse()
m.info()

輸出:
這是一個(gè)鼠標(biāo)

拓展1:

如果在多繼承中子類和父類方法同名了,父類方法被子類方法覆蓋了,但是我仍然想要調(diào)用父類的方法,那該怎么辦?


Python 類相當(dāng)于類空間,因此Python 類中的方法本質(zhì)上相當(dāng)于類空間內(nèi)的函數(shù)。
所以,即使是實(shí)例方法, Python 也允許通過類名調(diào)用。區(qū)別在于: 在通過類名調(diào)用實(shí)例方法時(shí),Python 不會(huì)為實(shí)例方法的第一個(gè)參數(shù)self 自動(dòng)綁定參數(shù)值,而是需要程序顯式綁定第一個(gè)參數(shù)self。這種機(jī)制被稱為未綁定方法。


再看代碼:


# 在Python的多繼承中,如果子類繼承的多個(gè)父類中包含了同名的方法,子類在調(diào)用時(shí)會(huì)選擇哪個(gè)  
class Item :
    def info (self):
        print("Item中的方法","這是一個(gè)商品")

class Product:
    def info(self):
        print("Product中的方法" , "這是一個(gè)工業(yè)產(chǎn)品")

class Mouse(Item, Product):
    def info(self):
        print("這是一個(gè)鼠標(biāo)")
    def all_method(self):
        self.info() #子類的info方法
        Item.info(self) #Item父類的info方法
        Product.info(self) #Product父類的info方法

m = Mouse()
m.all_method()

輸出結(jié)果:
這是一個(gè)鼠標(biāo)
Item中的方法 這是一個(gè)商品
Product中的方法 這是一個(gè)工業(yè)產(chǎn)品
這說明通過這種方法所有的info方法都被調(diào)用了

拓展2:

使用super函數(shù)調(diào)用父類的構(gòu)造方法
因?yàn)闃?gòu)造方法是Python內(nèi)置的特殊方法,在類中很常見,所以在多繼承中必須考慮子類怎么調(diào)用父類的構(gòu)造方法:


class Employee:
    def __init__(self, salary):
        self.salary = salary
    def work(self):
        print("普通員工正在寫代碼,工資是:", self.salary)

class Customer:
    def __init__(self, favorite, address):
        self.favorite = favorite
        self.address = address
    def info(self):
        print("我是一個(gè)顧客,我的愛好是%s, 地址是%s" %(self.favorite, self.address))

class Manger(Employee, Customer):
    pass

m = Manger(5000) #子類繼承的是父類Employee的構(gòu)造方法
m.work() #
m.info() #出錯(cuò),因?yàn)閕nfo中使用了Customer中定義的構(gòu)造屬性,但是子類并沒有從Customer中繼承favorite, address屬性

所以構(gòu)造方法很特殊,因?yàn)樗麨閷?duì)象初始化了屬性,這些屬性在其他方法中被使用,如果在子類繼承中不繼承父類的init方法,那么復(fù)用父類的一些方法,就會(huì)出現(xiàn)錯(cuò)誤,繼承的最大有點(diǎn)就是復(fù)用,如果不能復(fù)用,那么繼承毫無意義,所以我們必須在子類中重寫父類的構(gòu)造方法,繼承所有父類的init方法,同時(shí)也可以擴(kuò)展子類的屬性。繼承父類的init方法有兩種:

  1. 使用未綁定方法, 這種方式很容易理解。因?yàn)闃?gòu)造方法也是實(shí)例方法, 當(dāng)然可以通過這種方式來調(diào)用。
  2. 使用super()函數(shù)調(diào)用父類的構(gòu)造方法。

class Employee:
    def __init__(self, salary):
        self.salary = salary
    def work(self):
        print("普通員工正在寫代碼,工資是:", self.salary)

class Customer:
    def __init__(self, favorite, address):
        self.favorite = favorite
        self.address = address
    def info(self):
        print("我是一個(gè)顧客,我的愛好是%s, 地址是%s" %(self.favorite, self.address))

# class Manager(Employee, Customer):
#     pass
#
# m = Manager(5000) #子類繼承的是父類Employee的構(gòu)造方法
# m.work() #
# m.info() #出錯(cuò),因?yàn)閕nfo中使用了Customer中定義的構(gòu)造屬性,但是子類并沒有從Customer中繼承favorite, address屬性

class Manager(Employee, Customer):
    def __init__(self, salary, favorite, address, occupation): #重寫init,要寫所有父類中的init屬性,同時(shí)可以添加子類的屬性occupation
        self.occupation = "new add"
        print("這是Manager類的構(gòu)造方法")
        # 繼承Employee中的init方法,super方法,兩種寫法都可以
        # super().__init__(salary) #super寫法1
        super(Manager, self).__init__(salary) #super寫法2
        # 繼承Customer方法,通過調(diào)用未綁定的方法,顯式傳遞self
        Customer.__init__(self, favorite, address)

        print("我是子類Manager 初始化方法init中定義的屬性:", self.occupation)

m = Manager(5000, 'sing', 'china', 'IT')
m.work()
m.info()
向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI