Java中被final关键字标识的对象或者变量往往都意味着不能在运行时被动态更改,final的类则无法被继承。在C++中,变量可以用const声明为常量来表示相同的效果,而关于类的继承限制似乎没有相应的关键字予以实现,但借助于目前C++的相关机制,是能够手动实现final类的功能的,相关代码如下:
#include <iostream>
#include <string>
#include <vector>
#include <stack>
#include <map>
using namespace std;
template <typename T>
class MakeFriend
{
public:
typedef T type;
};
template <typename T>
class MakeFinal
{
friend class MakeFriend<T>:: type;//通过模板类封装友元类T
private:
MakeFinal(){};
~MakeFinal(){};
};
class FinalClass :virtual public MakeFinal<FinalClass>//通过虚继承实现的具有final关键字的类FinalClass 虚继承保证了必定会调用父类的构造函数
{
};
class TestFinalClass : public FinalClass
{
};
int main()
{
//TestFinalClass tfc;
TestFinalClass *tfc = new TestFinalClass();//出现编译错误,因为试图使用子类去调用父类的私有构造函数
FinalClass *fc = new FinalClass;//成功编译,在堆上分配资源
system("pause");
return 0;
}
主要的思想就是利用友元类的特性,使得final类可以访问其父类的构造函数,但由于友元特性是不能被继承的,因此其子类没有权限访问其基类的私有方法,最终实现final的功能,这样能够避免将基类构造方法定义为私有所导致的子类对象无法访问构造函数的情况,的确是一种非常巧妙的思路。