您好,登錄后才能下訂單哦!
這篇文章主要介紹“C++重載、重定義與重寫的用法詳解”,在日常操作中,相信很多人在C++重載、重定義與重寫的用法詳解問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”C++重載、重定義與重寫的用法詳解”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
重載函數是C++為了方便使用,允許在同一范圍中(一個類中)聲明幾個功能類似的同名函數,但是這些同名函數的形參(指參數的個數、類型或者順序至少有一個)必須不同
1、代碼實現在一個類中fun()函數的重載:
#include<iostream> using namespace std; class Base { public: void fun() { cout << "Base::fun()" << endl; } void fun(int a) { cout << "Base::fun(int)" << endl; } void fun(int a, float b) { cout << "Base::fun(int,float)" << endl; } }; void main() { Base c; c.fun(); c.fun(1); c.fun(1, 1.0); }
2、運行程序之后的打印
如果一個類,存在和父類相同的函數(此處指函數名相同,對返回類型、形參沒有要求),那么,這個類將會覆蓋其父類的方法,除非你在調用的時候,強制轉換為父類類型,否則試圖對子類和父類做類似重載的調用是不能成功的,此方法稱為重定義。(bb太多文字怕看官老爺暈乎乎,直接上代碼)
1、代碼實現在兩個類中分別定義一個函數(函數名要求相同):
class Base { public: void fun() { cout << "Base::fun()" << endl; } }; class D :public Base { public: void fun(int) { cout << "D fun(int)" << endl; } }; int main() { D d; //d.fun() 如果這樣調用 系統會提示缺少參數 d.fun(1);//同名隱藏,此時調用的是子類中的fun函數 //如果想調用父類對象,下面的語句可以幫你實現,你需要指出調用的是誰的fun d.Base::fun(); }
2、運行程序之后的打印
子類可繼承父類中的方法,而不需要重新編寫相同的方法。但有時子類并不想原封不動地繼承父類的方法,而是想作一定的修改,也就是子類重新定義父類中有相同名稱和參數的虛函數(virtual),這就需要采用方法的重寫。方法重寫又稱方法覆蓋。
1、代碼實現在子類重寫父類虛函數:
class Person { public: virtual void Eat() { cout << "Person Eat food" << endl; } virtual void sleep() { cout << "Person sleep " << endl; } void study() { cout << "We need study" << endl; } }; class Lily:public Person { public: virtual void Eat() { cout << "Lily Eat dumpling" << endl; } virtual void sleep() { cout << "Lily sleeps and dreams " << endl; } }; void main() { Lily L; /*子類對象不能直接調用被重寫的方法 因為對D實例化的對象來說重寫的函數覆蓋掉了父類的虛函數 */ Person *pr = &L; pr->Eat(); pr->sleep(); L.study(); }
2、運行程序之后的打印
我們看完三個方法的實現之后來做一個橫向比較:
函數 | 特點 |
---|---|
函數重載 | 在同一個類中,同名函數形參的個數、類型、順序至少有一個不同 |
重定義(同名隱藏) | 子類中存在和父類相同的函數(此處指函數名相同,對返回類型、形參沒有要求),屏蔽了父類的同名函數 |
重寫(覆蓋) | 子類對父類繼承的虛函數內容想做一定的修改 |
到此,關于“C++重載、重定義與重寫的用法詳解”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。