摘要:因此,之后的版本使用方法實現繼承。全稱,代表類的繼承順序。計劃年月底之前翻譯完成對講解最透徹的一篇文章是的一篇文章。
讀django類視圖代碼時,遇到這樣一個問題:
class A(object): def __init__(self): pass def get_data(self, **kwargs): print "enter A" if "A" not in kwargs: kwargs["A"] = "value A" print "leave A" return kwargs class B(A): def get_data(self, **kwargs): print "enter B" if "B" not in kwargs: kwargs["B"] = "value B" print "leave B" return super(B, self).get_data(**kwargs) class C(A): def get_data(self, **kwargs): print "enter C" if "C" not in kwargs: kwargs["C"] = "value C" print "leave C" return super(C, self).get_data(**kwargs) class D(C, B): def use_data(self): print "enter D" data = self.get_data(D="value D") print "data value:",data print "leave D" return if __name__ =="__main__": d = D() d.use_data()
這套程序中,D的use_data函數中的data的值應該是什么,這里的運行結果是:
enter D enter C leave C enter B leave B enter A leave A data value: {"A": "value A", "C": "value C", "B": "value B", "D": "value D"} leave D
需要注意的是:這里的A必須繼承object,如果A不繼承object,程序變成這樣:
class A(): def __init__(self): pass def get_data(self, **kwargs): print "enter A" if "A" not in kwargs: kwargs["A"] = "value A" print "leave A" return kwargs class B(A): def get_data(self, **kwargs): print "enter B" if "B" not in kwargs: kwargs["B"] = "value B" print "leave B" return super(B, self).get_data(**kwargs) class C(A): def get_data(self, **kwargs): print "enter C" if "C" not in kwargs: kwargs["C"] = "value C" print "leave C" return super(C, self).get_data(**kwargs) class D(C, B): def use_data(self): print "enter D" data = self.get_data(D="value D") print "data value:", data print "leave D" return if __name__ =="__main__": d = D() d.use_data()
運行結果會報錯:
/System/Library/Frameworks/Python.framework/Versions/2.7/bin/python2.7 /Users/apple/mygit/kd/demo/class_inheritance_example.py Traceback (most recent call last): enter D File "/Users/apple/mygit/kd/demo/class_inheritance_example.py", line 41, inenter C d.use_data() leave C File "/Users/apple/mygit/kd/demo/class_inheritance_example.py", line 34, in use_data data = self.get_data(D="value D") File "/Users/apple/mygit/kd/demo/class_inheritance_example.py", line 28, in get_data return super(C, self).get_data(**kwargs) TypeError: must be type, not classobj
這是python繼承問題,通過問度娘,找到好多文章,這里按自己的方式記錄整理,以備后續使用。
python實現繼承的方法python可以采用兩種方法實現繼承。
方法1:使用父類名,例:
class A: def __init__(self): print "enter A" print "leave A" class B(A): def __init__(self): print "enter B" A.__init__(self) print "leave B"
方法2,使用super,例:
class A: def __init__(self): print "enter A" print "leave A" class B(A): def __init__(self): print "enter B" super(C,self).__init__() print "leave B"
方法1是python2.2之前的版本實現繼承采用的方法。該方法的問題在于如果有多個繼承,當父類更改名字時,所有的子類都要進行相應修改。因此,python2.2之后的版本使用方法2實現繼承。
supersuper是MRO中的一個類。MRO全稱Method Resolution Order,代表類的繼承順序。
關于super,需要注意的一點是它是一個訪問排序器,而不是父類。
計劃2017年8月底之前翻譯完成對super講解最透徹的一篇文章是Raymond Hettinger的一篇文章https://rhettinger.wordpress....。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/40723.html
摘要:優先順序模糊多重繼承的優先順序,方法調用順序不明確。在松本行弘的松本行弘的程序世界中介紹了中類的幾個原則通常的繼承用單一繼承第二個以及兩個以上的父類必須是的抽象類中的多重繼承應該也適用。 我們前面理解了類。類就是把具體事物給抽象出來。其實也有歸類、類別的意思。我們舉一個例子:人的職業有Teacher、Coder、Writer、Singer等職業繼承關系就是: Pe...
摘要:解決的辦法在處理計算密集型任務時,使用多進程協程,發揮計算機多核的威力,而處理密集型,則可以使用多線程。至此,有關知識點的面試題就已告一段落,下次更新數據庫,方面面試題。 showImg(https://segmentfault.com/img/bVbuYzy?w=3484&h=2480); 閱讀本文大約需要 5 分鐘。 15.說一說 GIL 前面有提到由于 Python 基于 C 語...
摘要:今天我們介紹的主角是在類的繼承里面非常常用,它解決了子類調用父類方法的一些問題,父類多次被調用時只執行一次,優化了執行邏輯,下面我們就來詳細看一下。 1 談談你對面向對象的理解? 面向對象的編程---object oriented programming,簡稱:OOP,是一種編程的思想。OOP把對象當成一個程序的基本單元,一個對象包含了數據和操作數據的函數。面向對象的出現極大的提高了編...
摘要:時代,如果需要手動繼承,如多態多態是指,不同的子類對象調用相同的父類方法,會產生多態多樣結果的編程特性。 參考:黑馬程序員教程 - Python基礎 面向對象 OOP三大特性,且三個特性是有順序的: 封裝 繼承 多態 封裝 指的就是把現實世界的事務,封裝、抽象成編程里的對象,包括各種屬性和方法。這個一般都很簡單,不需要多講。 唯一要注意的就是:推薦從小往大開始封裝、開發類。比如手槍...
閱讀 2024·2021-09-30 09:47
閱讀 703·2021-09-22 15:43
閱讀 1981·2019-08-30 15:52
閱讀 2431·2019-08-30 15:52
閱讀 2540·2019-08-30 15:44
閱讀 903·2019-08-30 11:10
閱讀 3372·2019-08-29 16:21
閱讀 3296·2019-08-29 12:19