函数重载与虚函数的区别

 函数重载与虚函数的区别
 

重载函数,重载可以看作是静态的多态。函数重载的返回类型及所带的参数必须至少有一样不完全相同,只需函数名相同即可。

基类中定义的虚函数在派生类中重新定义时,其函数原型,包括返回类型、函数名、参数个数、参数类型及参数的先后顺序,都必须与基类中的原型完全相同。

重载虚函数时,若与基类中的函数原型出现不同,系统将根据不同情况分别处理:

(1)仅仅返回类型不同,其余相同,系统会当作出错处理;

(2)函数原型不同,仅仅函数名相同,系统会认为是一般的函数重载,将丢失虚特性。

当在多条继承路径上有一个公共的基类,在这些路径中的某几条汇合处,这个公共的基类就会产生多个实例(或多个副本),若只想保存这个基类的一个实例,可以将这个公共基类说明为虚基类。

派生类构造函数的调用次序有三个原则:

1) 虚基类的构造函数在非虚基类之前调用;

2) 若同一层次中包含多个虚基类,这些虚基类的构造函数按它们说明的次序调用;

3) 若虚基类由非虚基类派生而来,则仍先调用基类构造函数,再调用派生类的构造函数。         
                 
重载函数在类型和参数数量上一定不相同,而重定义的虚函数则要求参数的类型和个数、函数返回类型相同;
虚函数必须是类的成员函数,重载的函数则不一定是这样;
构造函数可以重载,但不能是虚函数,析构函数可以是虚函数。
                        
                        
例1:
                               
#include <iostream.h>
class CBase
...{
public:
    virtual int func(unsigned char ch) ...{return --ch;}
};
class CDerive : public CBase
...{
    int func(char ch) ...{return ++ch;}   //此为函数重载
};
void main()
...{    CBase *p=new CDerive;
    int n=p->func(40);        //调用基类的 func()
    cout<<" the result is : "<<n<<endl;
}
                     
运行结果:
       the result is : 39
                       
                  
例2:
                 
#include <iostream.h>
class CBase
...{
public:
    virtual int func(unsigned char ch) ...{return --ch;}
};
class CDerive : public CBase
...{
    int func(unsigned char ch) ...{return ++ch;}      //此为虚函数
};
void main()
...{    CBase *p=new CDerive;
    int n=p->func(40);        //调用派生类的 func()
    cout<<" the result is : "<<n<<endl;
}
                
               
运行结果:
        the result is : 41

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值