重载与覆盖的区别

        1重载:是指允许存在多个同名函数,而这些函数的参数表不同(或许参数个数不同,或许参数类型不同,或许两者都不同)。  

        编译器根据函数不同的参数表,对同名函数的名称做修饰,然后这些同名函数就成了不同的函数(至少对于编译器来说是这样的)。如,有两个同名函数:function func(p:integer):integer;function func(p:string):integer;。那么编译器做过修饰后的函数名称可能是这样的:int_funcstr_func。对于这两个函数的调用,在编译器间就已经确定了,是静态的。也就是说,它们的地址在编译期就绑定了(早绑定),因此,重载和多态无关!   

        2、覆盖:是指子类重新定义复类虚函数的方法。

        和多态真正相关。当子类重新定义了父类的虚函数后,父类指针根据赋给它的不同的子类指针,动态的调用属于子类的该函数,这样的函数调用在编译期间是无法确定的(调用的子类的虚函数的地址无法给出)。因此,这样的函数地址是在运行期绑定的(晚绑定)。

         3重载的特征: 

            (1)相同的范围(在同一个类中)方法的重载是同一个类中方法之间的关系,是水平关系

            (2)函数名字相同;

            (3)参数不同; 

            (4)virtual关键字可有可无

            5重载是多个方法之间的关系

            6重载关系,是根据调 用时的实参表与形参表来选择方法体的  

         4覆盖特征:

            (1)不同的范围(分别位于派生类与基类)方法的覆盖是子类和父类之间的关系,是垂直关系

            (2)函数名字相同;

            (3)参数相同; 

            (4)基类函数必须有virtual 关键字

            5只能由一个方法,或只能由一对方法产生关系;

            6覆盖关系中,调用那个方法体,是根据对象的类型(对象对应存储空间类型)来决定

           5 示 例 1 中 , 函 数Base::f(int) 与 Base::f(float) 相互重载, 而 Base::g(void) 被 Derived::g(void)覆盖。  



#include <iostream>  


class Base ...

{ public: 
    void f(int x)...{ cout << "Base::f(int) " << x << endl; }     

    void f(float x)...{ cout << "Base::f(float) " << x << endl; }     

     virtual void g(void)...{ cout << "Base::g(void)" << endl;} };  


class Derived : public Base ...

{ public: 
    virtual void g(void)...
{ cout << "Derived::g(void)" << endl;} };  


void main(void) ...


    Derived d;     Base *pb = &d; 
    pb->f(42);      // Base::f(int) 42   

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

    pb->g();    // Derived::g(void) }











你可能感兴趣的:(C++,多态,重载)