public class Q48不能被继承的类 {
//把构造函数设为私有函数
public static Q48不能被继承的类 getInstance()
{
return new Q48不能被继承的类();
}
public static void deleteInstance(Q48不能被继承的类 instance)
{
instance=null;
}
private Q48不能被继承的类(){};//私有构造函数
}
在C#中定义了关键字为sealed,被sealed修饰的类不能被继承。在Java中用的关键字是final,表示一个类不能被继承。该题目主要是针对C++实现的功能,但是同样可以用Java来定义一个私有构造函数,来避免一个类被继承。
在C++中子类的构造函数会自动调用父类的构造函数,子类的析构函数也会自动的调用父类的析构函数,因此会导致在继承时,调用构造函数和析构函数会导致编译错误。如果将一个类的构造函数和析构函数都设为私有函数,那么如何获得该类的实例对象就成为关键了。此时,通过定义公有的静态函数来创建和释放类的实例。
当然通过该方法得到的只能是堆上的实例,而得不到位于栈上的实例。
在C++中还可以通过一种较好的方法:利用虚拟继承。
template <typename T> classMakeSealed
{
friend T;
private :
MakeSealed(){}
~MakeSealed(){}
};
class SealedClass2 : virtual publicMakeSealed<SealedClass2>
{
public :
SealedClass2(){}
~SealedClass2(){}
};
说明:利用虚拟继承即可以创建栈上的实例也可以创建堆上的实例。尽管MakeSealed<SealedClass2>中的构造函数和析构函数都是私有的,但由于SealedClass2是友元类型,因此在SealedClass2中调用MakeSealed<SealedClass2>的构造函数和析构函数都不会引起编译错误。但是,当我们试图从SealedClass2中继承一个类并创建它的实例对象时,不能通过编译。