C++学习笔记-DLL中动态内存管理

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq78442761/article/details/83961874

动态内存管理
在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;
}

猜你喜欢

转载自blog.csdn.net/qq78442761/article/details/83961874