override关键字在c++++11中用于显式表明成员函数是对基类虚函数的重写,1. 明确代码意图并增强可读性,使开发者清晰知道该函数是重写基类方法;2. 在编译时检查是否正确重写,如拼写错误、参数不匹配等情况会触发编译错误;3. 避免因函数签名不一致导致隐藏基类函数的问题;4. 使用时需注意仅用于虚函数、保持const一致性及默认参数建议一致,从而提升代码质量与维护性。

在C++11中,override关键字用于显式地表明一个成员函数是对基类虚函数的重写。它本身不会改变程序的行为,但能帮助开发者更清晰地表达意图,并在编译时捕获一些常见的错误。

明确意图,增强代码可读性
当你在一个派生类中写了一个看起来像重写的函数时,别人阅读代码时可能会疑惑:这个函数真的是在重写基类的虚函数吗?有没有可能参数类型、常量性或返回值不一致?

加上override之后,就相当于告诉阅读者和编译器:“我明确知道我在重写一个虚函数。”这样不仅让代码意图更清楚,也减少了他人理解上的歧义。
立即学习“C++免费学习笔记(深入)”;
比如:

class Base {
public:
virtual void foo(int x);
};
class Derived : public Base {
public:
void foo(int x) override; // 清晰表明这是重写
};编译时检查,避免意外未重写
这是override最关键的作用之一。如果你试图重写一个基类函数,但由于拼写错误、参数类型不一致等原因导致实际上没有构成重写,加上override后,编译器会报错。
例如下面这段代码:
class Base {
public:
virtual void bar(int x);
};
class Derived : public Base {
public:
void barr(int x) override; // 拼写错误,编译器会报错
};因为barr并不是对bar的正确重写,使用override后,编译器就会提示你这个问题。如果不加override,这个错误可能被忽略,直到运行时才发现行为异常。
常见容易出错的情况包括:
- 函数名拼写不一致
- 参数类型不完全匹配
- 忘记
const修饰符 - 返回类型不同(虽然有时候允许协变返回类型)
避免隐藏基类函数
有时候你不小心定义了一个和基类函数“相似”的函数,但却不是正确的重写,这会导致基类的函数被隐藏。这种问题在继承层次较深时尤其难以发现。
使用override可以强制编译器确认你是否真的在重写一个虚函数,从而避免无意中隐藏了基类接口。
举个例子:
class Base {
public:
virtual void func(double x);
};
class Derived : public Base {
public:
void func(int x) override; // 错误!参数类型不匹配,无法重写
};这里,func(int)并不是对func(double)的重写,但由于加了override,编译器会立刻指出问题。
小细节提醒几个容易忽略的地方
-
override只能用于虚函数的重写,不能用在非虚函数或者非继承来的函数上。 - 如果基类函数是
const的,派生类重写时也必须带const,否则无法构成有效重写。 - 即使基类函数有默认参数,派生类也不一定需要保留同样的默认参数,但最好保持一致以避免混淆。
基本上就这些。override看似简单,但它带来的好处却很实在:提升代码清晰度、减少低级错误、增强维护性。用起来不复杂,但很容易被忽略。









