Q48:不能被继承的类 ——学习笔记

本文介绍了在C++和Java中如何设计不可被继承的类。在C++中可以通过使用私有构造函数和析构函数结合模板类实现,在Java中则通过final关键字实现。此外还讨论了如何通过静态方法创建和销毁此类的实例。

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中继承一个类并创建它的实例对象时,不能通过编译。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值