摘要:中使用多繼承,會(huì)涉及到查找順序重復(fù)調(diào)用鉆石繼承,也叫菱形繼承問(wèn)題等即,用于判斷子類調(diào)用的屬性來(lái)自于哪個(gè)父類。本地優(yōu)先級(jí)指聲明時(shí)父類的順序,比如,如果訪問(wèn)類對(duì)象屬性時(shí),應(yīng)該根據(jù)聲明順序,優(yōu)先查找類,然后再查找類。
python中使用多繼承,會(huì)涉及到查找順序(MRO)、重復(fù)調(diào)用(鉆石繼承,也叫菱形繼承問(wèn)題)等
MROMRO即method resolution order,用于判斷子類調(diào)用的屬性來(lái)自于哪個(gè)父類。在Python2.3之前,MRO是基于深度優(yōu)先算法的,自2.3開始使用C3算法,定義類時(shí)需要繼承object,這樣的類稱為新式類,否則為舊式類
從圖中可以看出,舊式類查找屬性時(shí)是深度優(yōu)先搜索,新式類則是廣度優(yōu)先搜索
C3算法最早被提出是用于Lisp的,應(yīng)用在Python中是為了解決原來(lái)基于深度優(yōu)先搜索算法不滿足本地優(yōu)先級(jí),和單調(diào)性的問(wèn)題。
本地優(yōu)先級(jí):指聲明時(shí)父類的順序,比如C(A,B),如果訪問(wèn)C類對(duì)象屬性時(shí),應(yīng)該根據(jù)聲明順序,優(yōu)先查找A類,然后再查找B類。
單調(diào)性:如果在C的解析順序中,A排在B的前面,那么在C的所有子類里,也必須滿足這個(gè)順序
示例看下面的例子
class X(object): def f(self): print "x" class A(X): def f(self): print "a" def extral(self): print "extral a" class B(X): def f(self): print "b" def extral(self): print "extral b" class C(A, B, X): def f(self): super(C, self).f() print "c" print C.mro() c = C() c.f() c.extral()
根據(jù)廣度搜索原則最先搜索到A,所以結(jié)果很明顯,如下所示
類C沒(méi)有extral函數(shù),調(diào)用的是子類的該函數(shù)。這種類的部分行為由父類來(lái)提供的行為,叫做抽象超類.
關(guān)于super從mro就能知道,super指的是 MRO 中的下一個(gè)類,而不是父類。super所做的事如下面代碼所示:
def super(cls, inst): mro = inst.__class__.mro() return mro[mro.index(cls) + 1]
對(duì)于在子類中調(diào)用父類方法,要么直接使用父類名來(lái)調(diào)用方法,要么在子類中用super,保持一致,最好不要混用
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/37640.html
摘要:因此,之后的版本使用方法實(shí)現(xiàn)繼承。全稱,代表類的繼承順序。計(jì)劃年月底之前翻譯完成對(duì)講解最透徹的一篇文章是的一篇文章。 讀django類視圖代碼時(shí),遇到這樣一個(gè)問(wèn)題: class A(object): def __init__(self): pass def get_data(self, **kwargs): print enter A ...
摘要:優(yōu)先順序模糊多重繼承的優(yōu)先順序,方法調(diào)用順序不明確。在松本行弘的松本行弘的程序世界中介紹了中類的幾個(gè)原則通常的繼承用單一繼承第二個(gè)以及兩個(gè)以上的父類必須是的抽象類中的多重繼承應(yīng)該也適用。 我們前面理解了類。類就是把具體事物給抽象出來(lái)。其實(shí)也有歸類、類別的意思。我們舉一個(gè)例子:人的職業(yè)有Teacher、Coder、Writer、Singer等職業(yè)繼承關(guān)系就是: Pe...
摘要:解決的辦法在處理計(jì)算密集型任務(wù)時(shí),使用多進(jìn)程協(xié)程,發(fā)揮計(jì)算機(jī)多核的威力,而處理密集型,則可以使用多線程。至此,有關(guān)知識(shí)點(diǎn)的面試題就已告一段落,下次更新數(shù)據(jù)庫(kù),方面面試題。 showImg(https://segmentfault.com/img/bVbuYzy?w=3484&h=2480); 閱讀本文大約需要 5 分鐘。 15.說(shuō)一說(shuō) GIL 前面有提到由于 Python 基于 C 語(yǔ)...
摘要:今天我們介紹的主角是在類的繼承里面非常常用,它解決了子類調(diào)用父類方法的一些問(wèn)題,父類多次被調(diào)用時(shí)只執(zhí)行一次,優(yōu)化了執(zhí)行邏輯,下面我們就來(lái)詳細(xì)看一下。 1 談?wù)勀銓?duì)面向?qū)ο蟮睦斫猓?面向?qū)ο蟮木幊?--object oriented programming,簡(jiǎn)稱:OOP,是一種編程的思想。OOP把對(duì)象當(dāng)成一個(gè)程序的基本單元,一個(gè)對(duì)象包含了數(shù)據(jù)和操作數(shù)據(jù)的函數(shù)。面向?qū)ο蟮某霈F(xiàn)極大的提高了編...
摘要:時(shí)代,如果需要手動(dòng)繼承,如多態(tài)多態(tài)是指,不同的子類對(duì)象調(diào)用相同的父類方法,會(huì)產(chǎn)生多態(tài)多樣結(jié)果的編程特性。 參考:黑馬程序員教程 - Python基礎(chǔ) 面向?qū)ο?OOP三大特性,且三個(gè)特性是有順序的: 封裝 繼承 多態(tài) 封裝 指的就是把現(xiàn)實(shí)世界的事務(wù),封裝、抽象成編程里的對(duì)象,包括各種屬性和方法。這個(gè)一般都很簡(jiǎn)單,不需要多講。 唯一要注意的就是:推薦從小往大開始封裝、開發(fā)類。比如手槍...
閱讀 3240·2021-11-24 09:39
閱讀 3179·2021-10-21 09:38
閱讀 2406·2019-08-29 15:28
閱讀 3748·2019-08-26 12:23
閱讀 2623·2019-08-26 12:19
閱讀 1368·2019-08-23 12:44
閱讀 2134·2019-08-23 12:02
閱讀 1006·2019-08-22 17:05