C++覆蓋和重載的區別
1、覆蓋
覆蓋也稱為重寫(override)。
覆蓋是存在類中,子類重寫從基類繼承過來的函數,函數名、返回值、參數列表都必須和基類相同。
當子類的對象調用成員函數的時候,如果成員函數有被覆蓋則調用子類中覆蓋的版本,否則調用從基類繼承過來的函數。
如果子類覆蓋的是基類的虛函數,則可以用來實現多態。當子類重新定義基類的虛函數之后,基類指針可以根據賦給它不同子類指針動態的調用子類中的虛函數,做到動態綁定,這就是多態。
2、重載
重載指允許在相同作用域中存在多個同名的函數,這些函數的參數表不同,編譯器根據函數不同的形參表對同名函數的名稱做修飾,然后這些同名函數就成了不同的函數。如:
- void Fun(int a);
- void Fun(double a);
- void Fun(int a, int b);
- void Fun(double a, int b);
重載要求參數列表必須不同,比如參數類型不同、參數個數不同、參數順序不同。如果僅僅是函數的返回值不同是沒辦法重載的。如:
- int Fun(int a)
- void Fun(int a)
函數被C++編譯后在符號庫中的名字與C語言的不同。假設某個函數的原型為:
- void foo( int x, int y);
該函數被C編譯器編譯后在符號庫中的名字為_foo;而C++編譯器則會產生像_foo_int_int之類的名字。
這樣的名字包含了函數名、函數參數數量及類型信息,C++就是靠這種機制來實現函數重載的。
3、重載與覆蓋的區別
- 重載要求函數名相同,但是參數列表必須不同;覆蓋要求函數名、參數列表、返回值必須相同。
- 重載描述的是同一個類中不同成員函數之間的關系;覆蓋是子類和基類之間不同成員函數之間的關系。
- 重載的確定是在編譯時確定,是靜態的;虛函數則是在運行時動態確定。