override用于确保派生类函数正确重写基类虚函数,final用于禁止类被继承或虚函数被重写,二者提升代码安全与清晰度。

在C++11中引入的final和override关键字,主要用于控制类的继承和虚函数的重写行为。它们让代码更安全、更清晰,也能帮助编译器提前发现错误。
override关键字的作用与用法
override用于派生类中的虚函数声明,表示该函数意在重写基类中的同名虚函数。如果函数签名不匹配或基类中没有对应的虚函数,编译器会报错。
使用override可以避免因拼写错误、参数类型不一致或const属性不一致导致的“意外隐藏”而非重写的问题。
示例:
立即学习“C++免费学习笔记(深入)”;
class Base {
public:
virtual void func(int x) const;
};
class Derived : public Base {
public:
void func(int x) const override; // 正确:签名一致
// void func(double x) override; // 错误:签名不匹配,编译失败
};
关键点:
- 必须出现在函数声明的末尾,在参数列表后(若有const或noexcept,放在其后)
- 只用于虚函数的重写场景
- 增强代码可读性,并由编译器验证是否真的完成了重写
final关键字的作用与用法
final有两个用途:一是防止类被继承,二是防止虚函数被进一步重写。
1. 修饰类:表示该类不能作为基类被继承
class Base final {
// ...
};
// class Derived : public Base { }; // 错误:Base是final的,不能继承
2. 修饰虚函数:表示该虚函数在派生类中不能再被重写
class Base {
public:
virtual void func() const final;
};
class Derived : public Base {
public:
// void func() const override; // 错误:func是final的,不能重写
};
使用final可以设计出“终止继承链”的类或方法,常用于框架设计中限制扩展行为。
override与final的区别总结
两者虽然都出现在成员函数声明的末尾,但目的不同:
- override:确保当前函数正确重写了基类虚函数,是给编译器的检查提示
- final:限制继承或重写行为,具有语义上的终结性作用
- 一个用于验证重写,另一个用于阻止继承或重写
- 可以同时使用:如
void func() override final;表示既重写基类函数,又禁止子类继续重写
基本上就这些。合理使用这两个关键字,能让面向对象设计更安全、意图更明确。











