以下摘自:http://topic.youkuaiyun.com/t/20031009/17/2338051.html
11 楼lop5712(LOP)
哈哈哈哈,真是搞笑,事实总是与想象差距甚远。一个模块一个堆,一个线程一个栈。
问题的一切都要归咎于C运行时期库是静态连接的。
我回去看了一下C运行时期库的源码,发现一个很搞笑的事实:CRT(C运行时期库)不是使用进程缺省的堆来实现malloc(new中调用malloc)的,而是使用一个全局句柄HANDLE __crtheap(好象是_crtheap,记不清了)来分配内存的。这个_crtheap是在XXXCRTStartUp(CRT提供的进口点函数)中创建的。
由于CRT静态连接,则楼主的DLL里有也有一个CRT,因此也有一个_crtheap。而在dll中的new使用dll中的_crtheap句柄分配堆,在exe中的delete使用exe中的_crtheap释放堆,当然失败!不信的话,楼主大可在你的exe和dll中各下一个断点,在变量查看中输入_crtheap来查看其值,一般会差个0x10000000-0x04000000,因为缺省dll的基址是0x10000000,而exe的是0x04000000。
因此你的模块也有一个与之相关联的堆了,因为使用C/C++语言编写,而且CRT静态连接。
To bluebohe(薄荷)
由于上面的原因,所以你说的第三个方法将无效,因为不能改变CRT静态连接和用C++编写的事实。不过由于没有试过,我也不敢妄下定论(我对CRT的运行机理还不了解),说它是错的,试过才知道。
5400

被折叠的 条评论
为什么被折叠?



