【C++11保姆级教程】final和override

简介: 【C++11保姆级教程】final和override

前言


在C++编程中,我们常常需要使用继承和多态来构建复杂的程序。然而,在继承关系中,有时候我们需要对继承层次做出一些限制,确保某些类或函数不能再被继承或重写。为了解决这个问题,C++11引入了两个关键字,分别是final和override。本篇教程将向大家介绍final和override的具体用法,帮助大家更好地理解和应用这两个关键字。


一、final关键字的使用


在C++中,final关键字用于修饰类、函数或虚函数,表示它们将是最终的,不能再被继承或重写。


1.1final关键字修饰类

当我们将一个类声明为final时,意味着该类不能再被其他类继承。这样可以保护基类的设计不受子类修改,防止继承滥用。例如:

class Animal final {  // 声明为final的类
    // ...
};
class Dog : public Animal {  // 编译错误,无法继承final类
    // ...
};


4b6d3bd867534479a63c50dfcf89008a.png


1.2final关键字修饰成员函数

当我们将一个成员函数声明为final时,意味着该函数不能被子类重写。这对于一些基类中实现了关键逻辑的函数非常有用,可以确保这些函数在派生类中不会被意外地修改。例如:

class Shape {
public:
    virtual void draw() final {  // 使用final修饰的虚函数
        // ...
    }
};
class Rectangle : public Shape {
public:
    void draw() {  // 编译错误,无法重写final函数
        // ...
    }
};


fbc424e6a17e45038afbdac3a5df9f93.png


1.3final的优势

1、类的最终性:通过使用final关键字修饰类,可以确保该类不能再被继承。这样可以保护基类的设计,防止子类进行不必要的修改或滥用继承关系。

2、函数的最终性:使用final关键字修饰函数可以防止派生类中对该函数的重写。这对于一些基类中实现了关键逻辑的函数非常有用,可以确保这些函数在派生类中不会被意外地修改,提高代码的可靠性和稳定性。


1.4final的劣势

1、限制了扩展性:使用final关键字修饰类或函数后,将无法进一步扩展或修改其行为。这可能在一些特殊情况下导致问题,如果未来需要对这些类或函数进行修改,就需要重新设计继承结构或重写相应代码。

2、降低灵活性:final关键字可能限制了代码的灵活性。在某些情况下,如果需要在派生类中对某个函数做一些微调或修改,但却无法实现,可能需要通过其他方式来解决问题。


二、override关键字的使用


在C++中,override关键字用于标记派生类中重新定义的虚函数,确保其与基类的虚函数相匹配。


2.1使用override关键字重写虚函数

当我们在派生类中使用override关键字重写虚函数时,如果基类中不存在与之匹配的虚函数,编译器将会报错。这有助于我们在编译时捕获潜在的错误。

class Animal {
public:
    virtual void makeSound() {
        // ...
    }
};
class Dog : public Animal {
public:
    void makeSound() override {  // 使用override关键字重写虚函数
        // ...
    }
};
class Cat : public Animal {
public:
    void mew() {
        // ...
    }
};

d276313bf15744b7b532d577bb47eaa6.png


2.3override的优势

1、需要手动添加:使用override关键字需要在派生类中显式地添加该关键字来标记函数的重写,这可能增加了一些冗余的代码。

2、只对虚函数有效:override关键字只能用于派生类对基类中的虚函数的重写,对于非虚函数或非继承关系,不能使用override关键字。


总结


final和override关键字在C++中提供了对类继承和函数重写行为的额外控制。final关键字可以保护基类不被修改,防止滥用继承,而override关键字可以明确标识派生类中对基类的虚函数的重写,并进行编译时类型检查。


然而,final关键字的使用可能限制了代码的扩展性和灵活性,而override关键字需要手动添加,并且只对虚函数有效。因此,在使用这两个关键字时,我们需要根据实际情况权衡其利弊,并确保在继承和重写方面遵循良好的设计原则和最佳实践。

相关文章
|
2月前
|
算法 数据挖掘 Shell
「毅硕|生信教程」 micromamba:mamba的C++实现,超越conda
还在为生信软件的安装配置而烦恼?micromamba(micromamba是mamba包管理器的小型版本,采用C++实现,具有mamba的核心功能,且体积更小,可以脱离conda独立运行,更易于部署)帮你解决!
74 1
|
2月前
|
存储 C++
c++的指针完整教程
本文提供了一个全面的C++指针教程,包括指针的声明与初始化、访问指针指向的值、指针运算、指针与函数的关系、动态内存分配,以及不同类型指针(如一级指针、二级指针、整型指针、字符指针、数组指针、函数指针、成员指针、void指针)的介绍,还提到了不同位数机器上指针大小的差异。
61 1
|
2月前
|
Linux C语言 C++
vsCode远程执行c和c++代码并操控linux服务器完整教程
这篇文章提供了一个完整的教程,介绍如何在Visual Studio Code中配置和使用插件来远程执行C和C++代码,并操控Linux服务器,包括安装VSCode、安装插件、配置插件、配置编译工具、升级glibc和编写代码进行调试的步骤。
354 0
vsCode远程执行c和c++代码并操控linux服务器完整教程
|
6月前
|
存储 算法 编译器
C++ 函数式编程教程
C++ 函数式编程学习
|
6月前
|
存储 编译器 开发工具
C++语言教程分享
C++语言教程分享
|
6月前
|
存储 编译器 C++
|
6月前
|
C++ 存储 索引
面向 C++ 的现代 CMake 教程(一)(5)
面向 C++ 的现代 CMake 教程(一)
109 0
|
6月前
|
缓存 存储 C++
面向 C++ 的现代 CMake 教程(一)(4)
面向 C++ 的现代 CMake 教程(一)
75 0
|
6月前
|
C++ 缓存 存储
面向 C++ 的现代 CMake 教程(一)(3)
面向 C++ 的现代 CMake 教程(一)
147 0
|
6月前
|
缓存 C++ Windows
面向 C++ 的现代 CMake 教程(一)(2)
面向 C++ 的现代 CMake 教程(一)
171 0