类被final修饰,不能被继承
- class A1 final { };
- class B1 : A1 { }; // “B1”: 无法从“A1”继承,因为它已被声明为“final”
class A1 final { };
class B1 : A1 { }; // “B1”: 无法从“A1”继承,因为它已被声明为“final”
虚函数被final修饰,不能被override
- class A1
- {
- virtual void func() final {}
- };
- class B1 : A1
- {
- virtual void func() {} //“A1::func”: 声明为“final”的函数无法被“B1::func”重写
- };
class A1
{
virtual void func() final {}
};
class B1 : A1
{
virtual void func() {} //“A1::func”: 声明为“final”的函数无法被“B1::func”重写
};
被override修饰后如果父类无对应的虚函数则报错,无法override,这个有什么作用呢,假如你想虚继承基类的函数,但是继承的时候写错了,参数类型不对或个数不对,但是编译没问题,运行时候缺和你设计的不一样不被调用,override就是辅助你检查是否继承了想要虚继承的函数
- struct A1
- {
- virtual void func(int) {}
- };
- struct B1 : A1
- {
- virtual void func(int) override {} // OK
- virtual void func(double) override {} // “B1::func”: 包含重写说明符“override”的方法没有重写任何基类方法
- };
//final,override出现在形参列表以及尾置返回类型之后
#include <iostream>
using namespace std;
struct B{
virtual void f1(int) const;
virtual void f2(int);
void f3(int) final;//出错,final不能修饰非虚函数
};
struct D:B{
void f1(int) const override ;//去掉const将出错,必须和基类中的函数原型一致,否则不能用override来表示覆盖
void f2(int) final;//final说明继承D的派生类中不能覆盖该函数
void f3();
};
struct E:B{
void f2(int);//ok,其直接基类B中该函数没有final说明符
};
struct F:D{
void f2(int);//出错,无法覆盖该函数,原因是其直接基类D中有final说明符
};
final 和override只能修饰虚函数,不能修饰非普通函数 ,final还可以修饰类,表示不能被继承;
final 可以用于基类和派生类,override用于派生类,override 和final可以同时出现在派生类中
final修饰的虚函数不能被重写,override当父类没有对应的虚函数时出错
struct A1
{
virtual void func(int) {}
};
struct B1 : A1
{
virtual void func(int) override {} // OK
virtual void func(double) override {} // “B1::func”: 包含重写说明符“override”的方法没有重写任何基类方法
};