学习了一段时间《剑指offer》现在做了一些笔试,现在陆续把笔记上传到博客,方便自己及他人上网查看。
题目:用C++ 设计一个不能被继承的类
常规解法:在C#中定义了关键字sealed,被这个关键字修饰的类不能被继承;在Java中同样也有关键字final,C++中没有类似的关键字,需要我们自己造轮子,在C++的子类的构造函数会自动调用父类的构造函数,析构函数也是如此,如果我们把它的构造函数和析构函数都定义为私有函数。
如果构造和析构都是私有,那么怎样才能得到该类的实例,可以通过定义共有的静态函数来创建和释放类的实例;
class A{
public:
static A* GetInstace()
{
return new A();
}
static void DeleteInstance(A* pA)
{
delete pA;
}
private:
A(){};
~A(){};
};
新奇的解法:利用虚拟继承,SealedClass2是MakeSealed的友元,所以可以调用私有函数。
template <typename T> class MakeSealed{
friend T;
private:
MakeSealed(){ cout << "MakeSealed()" << endl; }
~MakeSealed(){ cout << "~MakeSealed()" << endl; }
};
class SealedClass2 :virtual public MakeSealed<SealedClass2>{
public:
SealedClass2(){ cout << "SealedClass2()" << endl; }
~SealedClass2(){ cout << "~SealedClass2()" << endl; }
};
注意:在GCC中对friend的要求不同于VS目前最新的GCC中还不支持模板参数作为友元类型;