动态内存管理
在dll中malloc的内存,必须在dll中free
注:这是由Windows自己的特点决定!
如果 a 编译成静态库,有下面两种解决方法:
1.b.dll 和 c.dll 使用同一个款编译器编译(保证CRT库版本一致),编译选项都选择 /MD(/MDD),这样不需 要担心内存是谁释放的问题了,因为他们底层使用的是同一个Heap,可以随便使用!
2.不要在 b.dll 中分配内存,然后在 c.dll 中释放,因为他们底层使用的是不同的 Heap,可以在 b 中包装一下 a 提供的释放函数,再由c调用,这样 a 的分配和释放都是由 b.dll 控制的,在同一个堆内,就没事了!
如果 a 编译成动态库,那么
由于 a 内部得内存分配和释放都使用的是 a.dll 的堆,就不会堆不合法错误了。
遵循一些原则:
1. 尽量避免是直接使用其他DLL里面的全局对象。 因为DLL释放的时候,在其中的全局对象也会被释放, 有可能引起访问违例
2. DLL中导出了分配资源的函数, 则同时要导出对应的释放函数,否则很容易写出在分配是用new,释放使用free的情况。
如下面的dll代码:
#include <stdio.h>
#include <stdlib.h>
__declspec(dllexport) int* MyAlloc(int size){
int *p = (int*)malloc(size * sizeof(int));
for(int i = 0; i < size; i++){
p[i] = i;
}
return p;
}
__declspec(dllexport) void MyFree(int *p){
free(p);
}
调用源码:
#include <stdio.h>
#include <stdlib.h>
#pragma comment(lib, "MyDll.lib")
#define MYDLL __declspec(dllexport)
MYDLL int* MyAlloc(int size);
MYDLL void MyFree(int *p);
int main(){
int *p = MyAlloc(10);
for(int i = 0; i < 10; i++){
printf("%d\n", p[i]);
}
free(p);
getchar();
return 0;
}
运行截图如下:
解决这个问题,有2个方式,一个是一个款编译器编译(保证CRT库版本一致),编译选项都选择 /MD(/MDD)
如下图:
或者如下代码
#include <stdio.h>
#include <stdlib.h>
#pragma comment(lib, "MyDll.lib")
#define MYDLL __declspec(dllexport)
MYDLL int* MyAlloc(int size);
MYDLL void MyFree(int *p);
int main(){
int *p = MyAlloc(10);
for(int i = 0; i < 10; i++){
printf("%d\n", p[i]);
}
MyFree(p);
getchar();
return 0;
}