C++中的隱藏規則

C++中的隱藏規則

如果派生類的函數與基類的函數同名,但是參數不同,此時,無論有無virtual關鍵字,基類的函數將被隱藏(重載是一個類中有同名的函數)
如果派生類的函數與基類的函數同名,並且參數也相同,但是基類函數沒有virtual關鍵字,此時,基類的函數被隱藏(覆蓋是指基類函數有virtual關鍵字)
    #include <iostream>
    using namespace std;
    class Base{
    public:
        virtual void f(float x)
        {
            cout<<"Base::f(float) "<<x<<endl;
        }
        void g(float x)
        {
            cout<<"Base::g(float) "<<x<<endl;
        }
        void h(float x)
        {
            cout<<"Base::h(float) "<<endl;
        }
    };
    class Derived:public Base
    {
    public:
        void f(float x)
        {
            cout<<"Derived::f(float) "<<x<<endl;
        }
        void g(int x)
        {
            cout<<"Derived::g(int) "<<x<<endl;
        }
        void h(float x)
        {
            cout<<"Derived::h(float)"<<endl;
        }
    };

    int main()
    {
    Derived d;
    Base *pb=&d;
    Derived *pd=&d;

    pb->f(3.14f);
    pd->f(3.14f);

    pb->g(3.14f);
    pd->g(3.14f);

    pb->h(3.14f);
    pd->h(3.14f);

        return 0;
    } 

這裏寫圖片描述
運行結果如上圖所示,正常情況下,pb和pd指向相同的內存,所得的結果應該是相同的,但由於函數隱藏的結果,派生類的執行結果是派生類

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章