假設(shè)我有多個繼承方案:class A(object): # code for A hereclass B(object): # code for B hereclass C(A, B): def __init__(self): # What's the right code to write here to ensure # A.__init__ and B.__init__ get called?有寫作兩種典型的方法C的__init__:(老式) ParentClass.__init__(self)(較新的樣式) super(DerivedClass, self).__init__()但是,在任何一種情況下,如果父類(A和B)沒有遵循相同的約定,則代碼將無法正常工作(某些代碼可能會丟失或多次調(diào)用)。那么又是什么正確的方法呢?說“保持一致,遵循一個或另一個”很容易,但是如果A或B來自第三方圖書館,那又如何呢?有沒有一種方法可以確保所有父類構(gòu)造函數(shù)都被調(diào)用(以正確的順序,并且只能調(diào)用一次)?編輯:看看我的意思,如果我這樣做:class A(object): def __init__(self): print("Entering A") super(A, self).__init__() print("Leaving A")class B(object): def __init__(self): print("Entering B") super(B, self).__init__() print("Leaving B")class C(A, B): def __init__(self): print("Entering C") A.__init__(self) B.__init__(self) print("Leaving C")然后我得到:Entering CEntering AEntering BLeaving BLeaving AEntering BLeaving BLeaving C請注意,B的init被調(diào)用了兩次。如果我做:class A(object): def __init__(self): print("Entering A") print("Leaving A")class B(object): def __init__(self): print("Entering B") super(B, self).__init__() print("Leaving B")class C(A, B): def __init__(self): print("Entering C") super(C, self).__init__() print("Leaving C")然后我得到:Entering CEntering ALeaving ALeaving C請注意,Binit永遠不會被調(diào)用。因此,似乎除非我知道/控制我從(A和B)繼承的類的初始化,否則我無法對我正在編寫的類(C)做出安全的選擇。
3 回答

尚方寶劍之說
TA貢獻1788條經(jīng)驗 獲得超4個贊
如果要從第三方庫中繁衍子類類,則不會,沒有盲目的方法來調(diào)用__init__
實際上起作用的基類方法(或任何其他方法),而不管基類的編程方式如何。
super
使編寫旨在協(xié)作實現(xiàn)方法的類成為復(fù)雜的多重繼承樹的一部分成為可能,而類繼承者不必知道。但是沒有辦法使用它來正確地繼承可能使用或可能不使用的任意類super
。
本質(zhì)上,一個類是設(shè)計為使用super
基類還是直接調(diào)用基類進行子類化,是屬于該類“公共接口”一部分的屬性,因此應(yīng)進行記錄。如果您以庫作者所期望的方式使用第三方庫,并且?guī)炀哂泻侠淼奈臋n,則通常會告訴您對特定事物進行子類化需要執(zhí)行的操作。如果不是,則必須查看要子類化的類的源代碼,并查看其基類調(diào)用約定是什么。如果你是從一個或多個第三方庫的方式,該庫作者結(jié)合多個類沒想到,那么它可能無法始終如一地調(diào)用超類的方法在所有; 如果類A是使用的層次結(jié)構(gòu)的一部分,super
而類B是不使用super的層次結(jié)構(gòu)的一部分,則不能保證這兩種選擇都不會起作用。您將必須找出適合每種情況的策略。
添加回答
舉報
0/150
提交
取消