基类
class A
{
public:
virtual void func()
{
cout << "in class A" << endl;
}
};
后续的实验均以上面这个基类展开进行。
override
当class B继承了class A,并想重定义A的虚函数时,由于某种神秘力量,导致写成了这个样子:
class B : public A
{
public:
virtual void func(int n)
{
cout << "in class B" << endl;
}
};
编译器并不会报错,但是下面的代码将会输出"in class A"而不是期望中的"in class B"
int main()
{
A *p = new B;
p->func();
}
上面的测试代码槽点颇多,但我实在太困了
显然,我们可能需要某种方式来阻值我们意外地隐藏了基类的虚函数(正常情况下应该是覆盖基类的虚函数,注意这段话中加粗的2个动词,对于刚上路的新手来说,这种专业术语的运用还是要刻意练习的)
override关键字提供了这种功能:
class B : public A
{
public:
virtual void func(int n) override
{
cout << "in class B" << endl;
}
};
此时编译器会报错:member function declared with ‘override’ does not override a base class member
多么贴心啊!
final
在修正了class B的代码之后,现在变成了这个样子:
class B : public A
{
public:
virtual void func()
{
cout << "in class B" << endl;
}
};
此时,如果我希望B的继承者不要再覆盖这个虚函数了,可以用final关键字来阻止:
class B : public A
{
public:
virtual void func() final
{
cout << "in class B" << endl;
}
};
此时,如果有class C继承B后尝试覆盖虚函数func
:
class C : public B
{
public:
virtual void func()
{
cout << "in class C" << endl;
}
};
编译器会报错:cannot override ‘final’ function "B::func"
小结
override和final是C++11引入的新特性,但是它们2个其实并不是「关键字」,而是具有特殊含义的标识符。也就是说你可以把它们用作常规的标识符,比如声明一个名为override的变量。