c++中的隱藏、重載、覆蓋(重寫)


 1 重載與覆蓋

    成員函數被重載的特征:

(1)相同的范圍(在同一個類中);

(2)函數名字相同;

(3)參數不同;

(4)virtual關鍵字可有可無。 

    覆蓋是指派生類函數覆蓋基類函數,特征是:

(1)不同的范圍(分別位於派生類與基類);

(2)函數名字相同;

(3)參數相同;

(4)基類函數必須有virtual關鍵字。

 

令人迷惑的隱藏規則
本來僅僅區別重載與覆蓋並不算困難,但是C++的隱藏規則使問題復雜性陡然增加。這里“隱藏”是指派生類的函數屏蔽了與其同名的基類函數,規則如下:
(1)如果派生類的函數與基類的函數同名,但是參數不同。此時,不論有無virtual關鍵字,基類的函數將被隱藏(注意別與重載混淆)。
(2)如果派生類的函數與基類的函數同名,並且參數也相同,但是基類函數沒有virtual關鍵字。此時,基類的函數被隱藏(注意別與覆蓋混淆)。
上面的程序中:
(1)函數Derived::f(float)覆蓋了Base::f(float)。
(2)函數Derived::g(int)隱藏了Base::g(float),而不是重載。
(3)函數Derived::h(float)隱藏了Base::h(float),而不是覆蓋。

 

#include <iostream.h>

    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) " << x << endl; }
}; 


class Derived : public Base { public: virtual 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) " << x << endl; } };

 

void main(void)
{
    Derived d;
    Base *pb = &d;
   Derived *pd = &d;
// Good : behavior depends solely on type of the object

   pb->f(3.14f); // Derived::f(float) 3.14

   pd->f(3.14f); // Derived::f(float) 3.14
// Bad : behavior depends on type of the pointer

   pb->g(3.14f); // Base::g(float) 3.14

   pd->g(3.14f); // Derived::g(int) 3        (surprise!)

// Bad : behavior depends on type of the pointer

   pb->h(3.14f); // Base::h(float) 3.14      (surprise!)

  pd->h(3.14f); // Derived::h(float) 3.14
} 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM