
在C++11中引入的final和override关键字,用于更清晰地控制类的继承和虚函数的重写行为。它们虽然不改变程序的功能逻辑,但能提升代码的可读性,并帮助编译器在编译期发现错误。
final关键字的作用
final关键字可以用于类和虚函数,表示“禁止进一步派生”或“禁止进一步重写”。
• 修饰类:表示该类不能被继承。如果尝试从final类派生,编译器会报错。 • 修饰虚函数:表示该虚函数在派生类中不能被重写。若派生类试图重写该函数,将导致编译错误。
示例:
class Base final {
public:
virtual void func() {}
};
// class Derived : public Base {}; // 错误:Base是final类,不可继承
class A {
public:
virtual void foo() final {}
};
class B : public A {
// void foo() override; // 错误:foo被声明为final,不可重写
};
override关键字的作用
override关键字用于显式标明一个成员函数意在重写基类中的虚函数。它不是强制的,但强烈建议使用,因为能防止因函数签名不匹配而导致的“意外未重写”问题。
立即学习“C++免费学习笔记(深入)”;
• 如果函数声明了override,但没有匹配的基类虚函数,编译器会报错。 • 可提高代码可读性,明确表达设计意图。
常见错误场景(无override):
class Base {
public:
virtual void display(int x) {}
};
class Derived : public Base {
void display(double x) {} // 本意是重写,但参数类型不同,实际是重载
};
使用override后:
class Derived : public Base {
void display(double x) override {} // 编译错误:无匹配的基类虚函数
};
正确写法:
class Derived : public Base {
void display(int x) override {} // 正确重写
};
使用建议
• 在确实不想让类被继承时使用final,如工具类或性能敏感类。 • 所有明确要重写基类虚函数的派生类函数都应加上override。 • final和override可以一起使用,比如定义一个虚函数既被重写又不允许再被后续类重写。
示例:
class A {
public:
virtual void func() {}
};
class B : public A {
void func() override final {} // 重写并禁止进一步重写
};
class C : public B {
// void func() override; // 错误:func已是final
};
基本上就这些。合理使用final和override,能让继承体系更安全、意图更清晰。


