栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

两个模块类的static静态成员相互依赖,释放顺序错误导致crash问题

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

两个模块类的static静态成员相互依赖,释放顺序错误导致crash问题

#include
#include
using namespace std;

class A
{
public:
    A()
    {
            std::cout << "A  constuctor " << std::endl;
    }

    ~A()
    {
        cout << "A  delete" << endl;

    }
};

class B
{
public:
    B()
    {       std::cout << "B  constuctor " << std::endl;
            if( m_instance){
                    std::cout << "constructor when static member is not null " << std::endl;
            }

    };


    ~B()
    {

            std::cout << "B  deconstuctor delete " << std::endl;
            if( m_instance){
                    std::cout << "static member is not null " << std::endl;
            }
    };

   void  CallSmartPointer() {
       std::unique_ptr p;
      if (p == nullptr) {
          std::cout << "p is null " << std::endl;
      }
     m_instance.reset();
   }
private:
    static std::shared_ptr m_instance;
};

std::shared_ptr B::m_instance = std::shared_ptr(new A());
int main()
{
    B b;
    b.CallSmartPointer();
    return 0;
}
测试结果如下,

 当注释掉 m_instance.reset();这一行,不去主动释放智能指针,测试结果如下:

A delete 的打印会在进程结束时,才会释放资源。

        以上代码想说明的是,static静态成员智能指针的释放时机,可以手动控制,也可以由系统控制。

      发生问题的业务代码较多,要写清楚,篇幅太大,但是要理解这个问题的关键点,就是上面的概念即可串联起来解决问题。

       问题的发生还是因为,业务中有两个相互依赖的static变量值,当系统按照正确的顺序释放两个static变量值,不会出问题,但是系统释放顺序反了,就会导致内存破坏的crash问题。所以需要手动控制两个变量的内存释放顺序。

 

 

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/629975.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号