跨静态库的动态内存

dynamic memory across static libraries

本文关键字:动态 内存 静态      更新时间:2023-10-16

我有一个静态库,它包含了我的大部分代码/对象。我有另一个库,它继承了其中一些对象:E.G.

class SomeClass <-- from base library
class AnotherSomeClass : public SomeClass <--another library

在SomeClass中,我有另一个对象SomeObject,它也是以同样的方式继承的。

SomeObject *newobject = new AnotherSomeObject(); //for example SomeObject exists in one of the base classes in another library.

然后我向上转换以访问只存在于子类中的函数,如下所示:

AnotherSomeObject *object = (AnotherSomeObject*)newobject;

除了在基类中释放内存外,所有操作都很好。我得到了:_ASSERTE(_BLOCK_TYPE_IS_VALID(pHead->nBlockUse))

这是最近才出现的,很难诊断,因为在我对一些类进行一些更改之前,它一直运行良好。

我现在删除子类对象(它继承了基类对象),然后将基类对象设置为NULL,这似乎是有效的。

问题是为什么会发生这种情况?

继承时在基类中有一个虚拟析构函数很重要。

当您稍后在程序中调用delete时,如果您没有虚拟析构函数,编译器将生成调用析构函数的代码,该析构函数属于当前变量所属的类型。

因此,如果您持有基类类型的指针,则将使用基类析构函数
如果您持有指向派生类类型的指针,则将使用派生类析构函数。

这可能会导致各种各样的问题,最常见的情况是,你可以通过看到很难找到的内存泄漏来发现它。