轉自
http://blog.csdn.net/jixingzhong/article/details/1858943 重載overload,這個概念是大家熟知的。在同一可訪問區內被聲名的幾個具有不同參數列的(參數的類型、個數、順序不同)同名函數,程序會根據不同的參數列來確定具體調用哪個函數,這種機制就是重載。重載不關心函數的返回值類型,即返回類型不同無法構成重載。此外,C++ 中的const成員函數也可以構成overload。
總結一下重載的特征:
1、處在相同的空間中,即相同的范圍內;
2、函數名相同;
3、參數不同,即參數個數不同,或相同位置的參數類型不同;
4、const成員函數可以和非const成員函數形成重載;
5、virtual關鍵字、返回類型對是否夠成重載無任何影響。
覆蓋override,是指派生類中存在重新定義的函數,其函數名、參數列、返回值類型必須同父類中的相對應被覆蓋的函數嚴格一致,覆蓋函數和被覆蓋函數只有函數體(花括號中的部分)不同,當派生類對象調用子類中該同名函數時會自動調用子類中的覆蓋版本,而不是父類中的被覆蓋函數版本,這種機制就叫做覆蓋,特征是:
1、不同的范圍(分別位于派生類與基類);
2、函數名字相同;
3、參數相同;
4、基類函數必須有virtual關鍵字。
針對上述兩個概念,還有一個隱藏hide。所謂的隱藏,指的是派生類類型的對象、指針、引用訪問基類和派生類都有的同名函數時,訪問的是派生類的函數,即隱藏了基類的同名函數。隱藏規則的底層原因其實是C++的名字解析過程。在繼承機制下,派生類的類域被嵌套在基類的類域中。派生類的名字解析過程如下:
1、首先在派生類類域中查找該名字。
2、如果第一步中沒有成功查找到該名字,即在派生類的類域中無法對該名字進行解析,則編譯器在外圍基類類域對查找該名字的定義。
總結一下隱藏的特征:
1、如果派生類的函數與基類的函數同名,但是參數不同。此時,不論有無virtual關鍵字,基類的函數將被隱藏(注意別與重載混淆)。
2、如果派生類的函數與基類的函數同名,并且參數也相同,但是基類函數沒有virtual關鍵字。此時,基類的函數被隱藏(注意別與覆蓋混淆)。