在一个动态库中分配的内存然后在另一个库中删除通常会触发问题,如跨 dll 边界的内存分配和释放所示。我的问题与 auto_ptr 类型的对象有关。由 dll 提供的这种类型的对象非常棘手,因为使用 dll 的程序会自动删除该对象。但是,经常会发生一些内存重新分配操作可能会发生在 dll 库中的 auto_ptr 类型对象上。因此编写一个销毁 auto_ptr 类型对象的函数是必要的。首先,我给出下面的例子,它说明了在 dll 库中销毁 auto_ptr 类型对象的重要性。
.dll 库的头文件如下:
dll.h
class __declspec(dllexport) Image
{
public:
Image()
{
mem = NULL;
}
~Image()
{
std::cout<<"Image is being deleted!"<<std::endl;
delete []mem;
mem = NULL;
}
int *mem;
};
typedef std::auto_ptr<Image> ImagePtr;
class __declspec(dllexport) ImageReader
{
public:
void memory_reset(Image &img)
{
img.mem = new int [20*30];
}
};
调用dll库的可执行程序如下:
#include "dll.h"
#include <iostream>
#include <vector>
#include <numeric>
#include <iostream>
#include <algorithm>
#include <functional>
#include <iterator>
int main()
{
ImagePtr my_img(new Image());
ImageReader bmp_reader;
bmp_reader.memory_reset(*my_img);
return 0;
}
如果调用的运行时库是静态链接的(Multi-threaded Debug (/MTd)
),运行可执行程序时会出错:
为了解决这个问题,auto_ptr 对象必须被库删除。那么问题来了:删除这种类型的对象最好的方法是什么?我能想到的办法是提供一个可以删除auto_ptr对象的Global函数:
void Fun_destroy_memory(Image &img)
{
img.~Image();
}
所以可执行程序会变成:
int main()
{
ImagePtr my_img(new Image());
ImageReader bmp_reader;
bmp_reader.memory_reset(*my_img);
Fun_destroy_memory(*my_img);
return 0;
}
我不知道在这种情况下是否还有其他解决方案。另外,我想知道像我在Fun_destroy_memory
. 非常感谢!