C 過載重寫和多型區別

2021-10-18 23:44:22 字數 1783 閱讀 5978

1.過載和重寫的區別:

過載overload:在同乙個類中,函式名相同,引數列表不同,編譯器會根據這些函式的不同引數列表,將同名的函式名稱做修飾,從而生成一些不同名稱的預處理函式,未體現多型。

重寫override:也叫覆蓋,子類重新定義父類中有相同名稱相同引數的虛函式,主要是在繼承關係**現的,被重寫的函式必須是virtual的,重寫函式的訪問修飾符可以不同,儘管virtual是private的,子類中重寫函式改為public,protected也可以,體現了多型。

重定義redefining:也叫隱藏,子類重新定義父類中有相同名稱的非虛函式,引數列表可以相同可以不同,會覆蓋其父類的方法,未體現多型。

a如果派生類的函式和基類的函式同名,但是引數不同,此時,不管有無virtual,基類的函式被隱藏。

b如果派生類的函式與基類的函式同名,並且引數也相同,但是基類函式沒有vitual關鍵字,此時,基類的函式被隱藏。(如果有virtual就成重寫了)

[cpp]view plain

copy

#include 

using namespace std;  

class base  

void fun(string s)   

};  

class classa:public base  

//overload:注意這是過載而不是重寫,因為引數列表不同,在編譯時classa中其實還有個編譯器自己偷偷加上的從base繼承來的int function(){};  

};  

int main()  

執行結果:

2.多型性

「乙個介面,多種方法」,程式在執行時才決定呼叫的函式,c++的多型性是通過虛函式來實現的。最常見的用法就是宣告基類的指標,利用該指標指向任意乙個子類物件,呼叫相應的虛函式,可以根據指向的子類的不同而實現不同的方法。如果沒有使用虛函式的話,即沒有利用c++多型性,則利用基類指標呼叫相應的函式的時候,將總被限制在基類函式本身,而無法呼叫到子類中被重寫過的函式。因為沒有多型性,函式呼叫的位址將是一定的,而固定的位址將始終呼叫到同乙個函式,這就無法實現乙個介面,多種方法的目的了。

a編譯時多型性:通過過載函式實現 。

b執行時多型性:通過虛函式實現。

c++中, 虛函式可以為private, 並且可以被子類覆蓋(因為虛函式表的傳遞),但子類不能呼叫父類的private虛函式。虛函式的過載性和它宣告的許可權無關。

乙個成員函式被定義為private屬性,標誌著其只能被當前類的其他成員函式(或友元函式)所訪問。而virtual修飾符則強調父類的成員函式可以在子類中被重寫,因為重寫之時並沒有與父類發生任何的呼叫關係,故而重寫是被允許的。

編譯器不檢查虛函式的各類屬性。被virtual修飾的成員函式,不論他們是private、protect或是public的,都會被統一的放置到虛函式表中。對父類進行派生時,子類會繼承到擁有相同偏移位址的虛函式表(相同偏移位址指,各虛函式相對於vptr指標的偏移),則子類就會被允許對這些虛函式進行過載。且過載時可以給過載函式定義新的屬性,例如public,其只標誌著該過載函式在該子類中的訪問屬性為public,和父類的private屬性沒有任何關係!

純虛函式可以設計成私有的,不過這樣不允許在本類之外的非友元函式中直接呼叫它,子類中只有覆蓋這種純虛函式的義務,卻沒有呼叫它的權利。

C 過載重寫和多型區別

1.過載和重寫的區別 過載overload 在同乙個類中,函式名相同,引數列表不同,編譯器會根據這些函式的不同引數列表,將同名的函式名稱做修飾,從而生成一些不同名稱的預處理函式,未體現多型。重寫override 也叫覆蓋,子類重新定義父類中有相同名稱相同引數的虛函式,主要是在繼承關係 現的,被重寫的...

C 多型 過載重寫和重定義

c 中物件導向3大概念 封裝 突破c函式的概念 用類做函式引數的時候,可以使用物件的屬性 和物件的方法 繼承 a b 復用 多型 可以使用未來 實現多型的三個條件 1 要有繼承 2 要有虛函式重寫 3 用父類指標 父類引用 指向子類物件 class parent virtual void print...

C 過載 重寫 重定義 多型

多型是基於對抽象方法的覆蓋來實現的,用統一的對外介面來完成不同的功能。過載也是用統一的對外介面來完成不同的功能。那麼兩者有什麼區別呢?也叫覆蓋,子類重新定義父類中有相同名稱相同引數的虛函式,主要是在繼承關係中出現的,被重寫的函式必須是virtual的,重寫函式的訪問修飾符可以不同,儘管virtual...