final和override用于控制继承与重写:override确保派生类函数正确重写基类虚函数,避免签名不一致错误;final修饰类时禁止继承,修饰虚函数时禁止进一步重写,提升代码安全与可读性。

在C++11中,final和override是两个用于继承控制的关键字,它们增强了类继承体系的可读性和安全性。这两个关键字不是强制性的,但合理使用可以避免常见的继承错误,并让编译器帮助我们检查虚函数重写是否正确。
override关键字:确保正确重写虚函数
override关键字用于派生类的成员函数声明中,明确表示该函数意在重写基类中的虚函数。如果该函数实际上没有匹配任何基类的虚函数,编译器会报错。
它的主要作用是防止因函数签名不一致导致的“意外未重写”问题。
常见错误示例:
立即学习“C++免费学习笔记(深入)”;
- 参数类型写错(比如int写成size_t)
- const属性遗漏
- 函数名拼写错误
加上override后,编译器会验证该函数是否真正重写了基类的虚函数,否则报错。
用法示例:
class Base {
public:
virtual void func(int x) const;
};
class Derived : public Base {
public:
void func(int x) const override; // 正确重写
// void func(int x) override; // 错误:缺少const,无法匹配,编译失败
};
使用override是一种良好的编程习惯,能显著提升代码的健壮性。
final关键字:禁止进一步继承或重写
final关键字有两种用途:限制类被继承,或限制虚函数被重写。
1. 修饰类:禁止派生
当一个类被声明为final,它不能作为基类被继承。
class Base final {
// ...
};
// class Derived : public Base { }; // 编译错误:Base是final类
2. 修饰虚函数:禁止重写
当虚函数被标记为final,派生类不能再重写该函数。
class Base {
public:
virtual void func() final;
};
class Derived : public Base {
public:
// void func() override; // 编译错误:func是final函数,不能重写
};
注意:final函数仍必须是虚函数才能被重写控制,但它阻止后续派生类继续重写。
实际使用建议
在设计类体系时,合理使用这两个关键字有助于表达设计意图:
- 对于不希望被继承的类(如工具类、特定实现类),使用final明确禁止继承。
- 对于不希望被进一步重写的虚函数,使用final防止行为被篡改。
- 所有意图重写基类虚函数的成员函数都应加上override,提高代码可读性和安全性。
基本上就这些。这两个关键字虽然小,但在大型项目中对维护继承关系非常有帮助,建议在C++11及以上项目中积极使用。











