[c++] 单例模式的实例释放问题

要点:

1)静态变量在应用程序退出时会被销毁,也在此时其析构函数会被调用;

2)静态指针的销毁不会伴随析构函数的调用,因此不能指望static sigleton* _instance的销毁来触发析构函数;

3)在类的析构函数中delete自己会造成无限迭代循环,因此不能在自己的析构函数中 delete _instance 企图销毁单例。

 

例子:

class CommonUse : public QObject
{
    class GC
    {
        ~GC(){
            if(CommonUse::_instance){
                delete CommonUse::_instance;
            }
        }
    };

    Q_OBJECT

public:
    explicit CommonUse(QObject *parent = nullptr);
    static CommonUse* getCommonUse();

private:
    static CommonUse* _instance;
    static GC _gc;  //应用程序终结时,会销毁所有static变量,因此会触发GC的析构函数

};

 

参考:

https://blog.csdn.net/linuxwuj/article/details/81187564?utm_medium=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-1.nonecase&depth_1-utm_source=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-1.nonecase

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
单例模式是一种常见的软件设计模式,其目的是确保一个类只有一个实例,并提供一个全局访问点。 在实际应用中,单例模式有以下几个常见的应用场景。 1. 数据库连接:数据库连接是一种昂贵的资源,每次创建和释放数据库连接都会消耗大量的系统资源,降低系统性能。采用单例模式可以确保整个系统中只有一个数据库连接实例,多个线程共享该实例,避免创建多个连接造成资源浪费。 2. 日志记录器:在多个模块中需要进行日志记录的情况下,使用单例模式可以确保只有一个日志记录器实例,避免日志信息重复输出和资源浪费。 3. 配置文件解析器:在读取和解析配置文件时,使用单例模式可以确保只有一个配置文件解析器实例,避免多次读取配置文件和解析造成资源浪费。 4. 线程池:线程池是一种常见的线程管理机制,通过实现单例模式可以确保系统中只有一个线程池实例,多个线程共享该实例,提高系统性能和资源利用率。 总的来说,单例模式的应用场景主要是在需要确保只有一个实例对象,并且多个模块需要访问该对象时。通过单例模式可以避免资源的多次创建和释放,提高系统性能和资源利用率。但需要注意的是,单例模式也有一些缺点,如可能造成对象的生命周期过长,容易导致内存泄漏等问题,使用时需要慎重考虑。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值