您好,登錄后才能下訂單哦!
python中實現(xiàn)多態(tài)的方法?這個問題可能是我們?nèi)粘W(xué)習(xí)或工作經(jīng)常見到的。希望通過這個問題能讓你收獲頗深。下面是小編給大家?guī)淼膮⒖純?nèi)容,讓我們一起來看看吧!
多態(tài)是指通過基類的指針或者引用,在運行時動態(tài)調(diào)用實際綁定對象函數(shù)的行為。
對于其他如C++的語言,多態(tài)是通過在基類的函數(shù)前加上virtual關(guān)鍵字,在派生類中重寫該函數(shù),運行時將會根據(jù)對象的實際類型來調(diào)用相應(yīng)的函數(shù)。如果對象類型是派生類,就調(diào)用派生類的函數(shù);如果對象類型是基類,就調(diào)用基類的函數(shù)。
class A { public: virtual void show() { cout <<"A"; } }; class B:public A { public: void show() { cout << "B"; } }; int main() { A*p = new B(); //父類指針指向子類對象 p->show(); }
而在python中,可以這么寫:
class A: def say(self): print('A') class B: def say(self): print('B') def say(obj): obj.say() a = A() say(a)
那么,它內(nèi)部是怎么實現(xiàn)的呢?
首先,我們先看一下Python源碼中的object.h文件的頂部注釋:
在第一句里面寫著,對象總是通過指針PyObject *來訪問。那么什么是PyObject呢。
在Python中,所有的東西都是對象,而PyObject里面是所有對象中所擁有的相同的內(nèi)容。
我們來看兩個結(jié)構(gòu)體:
typedef struct _object { _PyObject_HEAD_EXTRA Py_ssize_t ob_refcnt; struct _typeobject *ob_type; } PyObject; typedef struct { PyObject ob_base; Py_ssize_t ob_size; /* Number of items in variable part */ } PyVarObject;
第一個就是PyObject,而第二個,我們根據(jù)名字就可以知道這是可變的對象的結(jié)構(gòu)體,包含了一個PyObject和一個所容納元素的個數(shù)部分。
當(dāng)我們創(chuàng)建一個對象時,分配內(nèi)存進行初始化,這時候會用一個PyObject類型的指針變量來指向這塊內(nèi)存進行保存和維護。
就像我們聲明一個整數(shù),得到整數(shù)對象,用于指向這塊內(nèi)存地址的,不是PyIntObject *,而是PyObject *。
其實類型本身也是一種對象,PyTypeObject。當(dāng)我們實例化一個整數(shù)對象的時候。PyIntObject的ob_type指針指向PyInt_Type,而PyInt_Type的ob_type又指向PyType_Type。而PyInt_Type和PyType_Type其實都是PyTypeObject的示例。
所以,我們在傳遞對象的時候,傳遞的是PyObject *指針這種泛型指針,我們只能通過ob_type進行判斷對象類型,通過傳遞泛型指針的方式,實現(xiàn)了Python的多態(tài)。
感謝各位的閱讀!看完上述內(nèi)容,你們對python中實現(xiàn)多態(tài)的方法大概了解了嗎?希望文章內(nèi)容對大家有所幫助。如果想了解更多相關(guān)文章內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。