如果在基类的虚函数声明中加上了final关键字,则表明后续的派生类不能重写该函数。
1 基类的虚函数上加上final关键字
表明基类后续的派生类不能重写该虚函数。
代码示例:
#include <iostream>
#include <memory>
using namespace std;
class Shape
{
public:
virtual void Area() final
{
std::cout << "Shape Area" << std::endl;
}
};
class Triangle : public Shape
{
public:
// 编译错误
virtual void Area()
{
std::cout << "Triangle Area" << std::endl;
}
};
int main()
{
std::shared_ptr<Triangle> pTriangle = std::make_shared<Triangle>();
pTriangle->Area();
getchar();
return 0;
}
我们在基类Shape中普通虚函数Area中增加了final关键字,又在派生类Triangle中增加了Area的实现,此时编译器会报错。
2 派生类的虚函数加上关键字final
在派生类的虚函数加上关键final说明该派生类后续的派生类不能重写该函数!
#include <iostream>
#include <memory>
using namespace std;
class Shape
{
public:
virtual void Area()
{
std::cout << "Shape Area" << std::endl;
}
};
class Triangle : public Shape
{
public:
virtual void Area() final;
};
class MyTriangle : public Triangle
{
public:
// 编译错误
virtual void Area()
{
std::cout << "Triangle Area" << std::endl;
}
};
int main()
{
std::shared_ptr<Triangle> pTriangle = std::make_shared<Triangle>();
pTriangle->Area();
getchar();
return 0;
}
3 派生类的虚函数同时加上关键字override和final
在派生类类的虚函数加上关键字override和final,说明派生类后续的派生类不能重写该函数,但是当前派生类可以重写当前基类的虚函数!
#include <iostream>
#include <memory>
using namespace std;
class Shape
{
public:
virtual void Area()
{
std::cout << "Shape Area" << std::endl;
}
};
class Triangle : public Shape
{
public:
// 正确
virtual void Area() override final
{
std::cout << "Triangle Area" << std::endl;
}
};
class MyTriangle : public Triangle
{
public:
// 编译错误
virtual void Area() override
{
std::cout << "Triangle Area" << std::endl;
}
};
int main()
{
std::shared_ptr<Triangle> pTriangle = std::make_shared<Triangle>();
pTriangle->Area();
getchar();
return 0;
}
本文作者:StubbornHuang
版权声明:本文为站长原创文章,如果转载请注明原文链接!
原文标题:C++ 11 – final关键字简要介绍
原文链接:https://www.stubbornhuang.com/932/
发布于:2020年10月12日 17:20:19
修改于:2023年06月26日 22:12:04
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
评论
50