和其他函数一样,虚函数也可以有默认参数。
书面说法是,如果某次函数调用使用了默认实参,则该实参由本次调用的静态类型决定。
换句话说,就是如果用一个基类的引用或者指针调用了一个虚函数,并且使用了默认实参,那么不管这个指针指向的对象是基类对象还是子类对象,都使用基类中声明的那个实参值。
下面举个栗子,
class t1{
public:
virtual void print(int i=45){cout << i << endl; cout << "Base class";}
};
class t2: public t1{
public:
void print(int i=33) override {cout << i << endl; cout << "Derived class";}
};
int main() {
t2 d;
t1 *p = &d;
d.print();
p->print();
return 0;
}
实际上输出是
可以看到,尽管p指向了一个子类对象,调用了一个虚函数,使用的却是基类中在声明时给定的默认实参。但是调用的确实是子类的那个函数。
所以,如果在虚函数中使用默认实参,那么在子类中应该使用与基类相同的默认值,以避免误用。