虚拟函数中的缺省实参,源自 c++ primer

#include <iostream.h>
class base{
public:
 virtual int foo(int ival = 1024){
  cout<<"base:ival=1024"<<endl;
  return ival;
 }
};

class derived:public base{
public:
 virtual int foo(int ival=2048)
 {
  cout<<"derived:ival = 2048"<<endl;
  return ival;
 }
};
void main()
{
 derived *pd = new derived;
 base *pb = pd;
 int ival = pb->foo();
 cout<<"really ival:"<<ival<<endl;

 ival = pd->foo();
 cout<<"really ival:"<<ival<<endl;

}

我们看以上的例子,有C++知识的人都应该知道, pb->foo()与pd->foo()都应该调用的是继承类中的foo();

事实也是如此,但是在这两个例子中传递给函数的缺省实参却不一样;我们来看下结果。

derived:ival = 2048

really ival:1024

derived:ival = 2048

really ival:2048

C++Primer中的解释是 虚拟函数中的缺省实参是在编译时刻根据被调用函数的对象的类型决定的。所以会出现这种结果。

posted @ 2011-05-24 23:28  flyblue  阅读(206)  评论(0编辑  收藏  举报