谁申请,谁释放。
VOID ExeFunc()
{
PVOID pv = DLLFunc();
// do somtehing via pv
free(pv);
}
PVOID DLLFunc()
{
return(malloc(100));
}
上面的代码表示,在DLL的函数DLLFunc申请内存,而在Exe的函数ExeFunc()中释放,有问题吗?
不一定。
结果与c/c++运行时库的链接方式有关,在vs中就是 property - Configuration Properties - c/c++ - Code Generation - Runtime Library中的设置
这几个选项详细的意思很多地方都有介绍,这里就不说了,只说一点就是,不带DLL的表示静态链接运行时库,当然,问题也就在这里。
如果上面的Exe和DLL其中有一个或者两个都是静态链接运行时库,那么上面的代码会有问题。
CRT(C运行时期库)不是使用进程缺省的堆来实现malloc(new中调用malloc)的,而是使用一个全局句柄HANDLE _crtheap来分配内存的。这个_crtheap是在XXXCRTStartUp(CRT提供的进口点函数)中创建的。
由于CRT静态连接,则DLL里有也有一个CRT,因此也有一个_crtheap。而在dll中的new使用dll中的_crtheap句柄分配堆,在exe中的delete使用exe中的_crtheap释放堆,当然失败!
new其实也会调用malloc