在C++11中,override确保虚函数正确重写,避免签名不匹配错误;final用于禁止类被继承或虚函数被重写,提升代码安全与可读性。

在C++11中引入的final和override关键字,用于更清晰地控制类的继承和虚函数重写行为。它们不是强制性的,但能提升代码可读性并帮助编译器捕捉错误。
使用override来表明一个成员函数意图重写基类中的虚函数。如果实际上没有匹配到任何虚函数,编译器会报错。
常见问题比如参数类型不一致、const属性不同、函数签名不匹配等,加上override后就能被及时发现。
示例:
立即学习“C++免费学习笔记(深入)”;
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可以用在两个地方:类名后或虚函数声明后。
1. 修饰类:防止被继承
在类名后加上final,表示该类不能作为基类被继承。
示例:
立即学习“C++免费学习笔记(深入)”;
class Base final {
// ...
};
// class Derived : public Base { }; // 编译错误:Base是final类
2. 修饰虚函数:禁止子类重写
在虚函数声明后加final,表示派生类不能再重写这个函数。
示例:
立即学习“C++免费学习笔记(深入)”;
class Base {
public:
virtual void func() const final;
};
class Derived : public Base {
public:
// void func() const override; // 错误:func是final函数,不能重写
};
实际开发中,常配合使用这两个关键字来设计稳定的类层次结构。
例如,定义一个不允许被修改行为的接口实现:
class Interface {
public:
virtual void doWork() = 0;
};
class StandardImpl : public Interface {
public:
void doWork() override final; // 实现并禁止进一步重写
};
class SpecialImpl : public StandardImpl {
// void doWork(); // 错误:StandardImpl::doWork 是 final
};
又或者某个类设计为不可继承:
class Utility final {
public:
static void help();
};
// class MyUtil : public Utility { }; // 错误:Utility是final类
基本上就这些。用好override可以避免重写失败而不自知的问题,而final则提供了一种明确的“封口”机制,增强封装性和设计意图表达。
以上就是c++++中final和override关键字怎么用_c++ final override关键字解析的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号