c++的virtual和override作用及說明
一、概述
c++的virtual提供了運行時的多態(tài),可以用基類的指針調(diào)用子類對象的函數(shù),通過override可以強制要求基類有對應(yīng)的虛函數(shù)。
二、測試代碼
#pragma once #include <stdio.h> class Base { public: ?? ?void A_1()? ?? ?{ ?? ??? ?printf("Base::A_1\n"); ?? ?}; ?? ?virtual void A_2()? ?? ?{ ?? ??? ?printf("Base::A_2\n"); ?? ?} ?? ?virtual void A_3()? ?? ?{ ?? ??? ?printf("Base::A_3\n"); ?? ?} ?? ?virtual void A_4() ?? ?{ ?? ??? ?printf("Base::A_4\n"); ?? ?} ?? ?void A_5()? ?? ?{ ?? ??? ?printf("Base::A_5\n"); ?? ?} }; class Drived : public Base { public: ?? ?void A_1() //覆蓋了基類的函數(shù),用基類指針調(diào)用時調(diào)用到的時基類的A_1,用子類指針調(diào)用時調(diào)用到的時子類的A_1 ?? ?{ ?? ??? ?printf("Drived::A_1\n"); ?? ?}; ?? ?virtual void A_2() //用基類或子類指針都調(diào)用到的是子類的A_2,之類的virtual說明的是是子類的A_2還可以被virtual ?? ?{ ?? ??? ?printf("Drived::A_2\n"); ?? ?} ?? ?void A_3() //用基類或子類指針都調(diào)用到的是子類的A_2 ?? ?{ ?? ??? ?printf("Drived::A_3\n"); ?? ?} ?? ?virtual void A_4() override //子類加上override,如果基類沒有對應(yīng)virtual函數(shù)就會編譯錯誤。避免拼錯和記錯沒有重寫基類函數(shù) ?? ?{ ?? ??? ?printf("Drived::A_4\n"); ?? ?} ?? ?/* ?? ?void A_5() override //編譯錯誤 'Drived::A_5': method with override specifier 'override' did not override any base class methods?? ? ?? ?{? ?? ??? ?printf("Drived::A_5\n"); ?? ?} ?? ?*/ }; class Drived2 : public Drived { public: ?? ?void A_2() override? ?? ?{ ?? ??? ?printf("Drived2::A_2\n"); ?? ?} ?? ?void A_3() ?override//用基類或子類指針都調(diào)用到的是子類的A_2 ?? ?{ ?? ??? ?printf("Drived2::A_3\n"); ?? ?} }; class VirtualTest { public: ?? ?void DoTest() ?? ?{ ?? ??? ?Drived *drived = new Drived(); ?? ??? ?Base *base = drived; ?? ??? ?base->A_1(); ?? ??? ?drived->A_1(); ?? ??? ?printf("\n"); ?? ??? ?base->A_2(); ?? ??? ?drived->A_2(); ?? ??? ?printf("\n"); ?? ??? ?base->A_3(); ?? ??? ?drived->A_3(); ?? ??? ?printf("\n"); ?? ??? ?base->A_4(); ?? ??? ?drived->A_4(); ?? ??? ?printf("\n"); ?? ??? ?Drived2 *drived2 = new Drived2(); ?? ??? ?base = drived2; ?? ??? ?drived = drived2; ?? ??? ? ?? ??? ?base->A_2(); ?? ??? ?drived->A_2(); ?? ??? ?drived2->A_2(); ?? ??? ?printf("\n"); ?? ??? ?base->A_3(); ?? ??? ?drived->A_3(); ?? ??? ?drived2->A_3(); ?? ?} };
三、輸出
Base::A_1
Drived::A_1Drived::A_2
Drived::A_2Drived::A_3
Drived::A_3Drived::A_4
Drived::A_4Drived2::A_2
Drived2::A_2
Drived2::A_2Drived2::A_3
Drived2::A_3
Drived2::A_3
四、總結(jié)
1、基類函數(shù)沒加virtual,子類有相同函數(shù),實現(xiàn)的是覆蓋。用基類指針調(diào)用時,調(diào)用到的是基類的函數(shù);用子類指針調(diào)用時,調(diào)用到的是子類的函數(shù)。
2、基類函數(shù)加了virtual時,實現(xiàn)的時重寫。用基類指針或子類指針調(diào)用時,調(diào)用到的都是子類的函數(shù)。
3、函數(shù)加上override,強制要求基本相同函數(shù)需要是虛函數(shù),否則會編譯報錯。
4、子類的virtual可加可不加,建議加override不加virtual。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
C語言實現(xiàn)從文件讀入一個3*3數(shù)組,并計算每行的平均值
今天小編就為大家分享一篇C語言實現(xiàn)從文件讀入一個3*3數(shù)組,并計算每行的平均值,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-12-12C++數(shù)據(jù)結(jié)構(gòu)分析多態(tài)的實現(xiàn)與原理及抽象類
繼承就是可以直接使用前輩的屬性和方法。自然界如果沒有繼承,那一切都是處于混沌狀態(tài)。多態(tài)是同一個行為具有多個不同表現(xiàn)形式或形態(tài)的能力。多態(tài)就是同一個接口,使用不同的實例而執(zhí)行不同操作2022-02-02