假定Derived继承Base,并且Base将下面的函数定义为虚函数;假定Derived打算定义自己的这个虚函数的版本,确定在Derived中哪个声明是错误的,并指出为什么错
a、Base* Base::copy(Base*);
Base* Derived::copy(Derived*);
b、Base* Base::copy(Base*);
Derived* Derived::copy(Base*);
c、ostream& Base::print(int, ostream& = cout );
ostream& Derived::print(int, ostream&);
d、void Base::eval() const;
void Derived::eval();
我整理的答案如下:
a,d错
b,c对
a:参数不一致;
b:如果虚函数的基类实例返回类类型的引用或指针,则该虚函数的派生类实例可以返回基类实例返回的类型的派生类(或者是类类型的指针或引用)。---C++Primer。
c:
C++中,所有的函数在调用前都必须事先声明。——C++编程思想
另外,参数缺省值必须是在生命中出现。
所以个人理解是这样的:
当调用包含缺省值参数的函数时,又没有给相应的参数传参,编译期编译器根据函数声明内部把缺省值传递给被调用参数。
根据这个理解,缺省参数只是编译器耍的一些小技巧,所以c是正确的。
d:
void Base::eval() const;
void Base::eval() ;
这两个函数属于重载关系。
所以 void Derived::eval();重写的是void Base::eval();
该题是一位csdn网友贴上来的,链接如下: