C++ 使用DLL启用gflags完全堆不会';行不通
我正在尝试使用调试gflags工具启用带有DLL选项的完整页面堆。这将允许对应用程序启用整页堆,但仅对指定的DLL启用整页堆 当我不使用DLL选项时,它可以正常工作。我能够在任何试图在分配的内存块上进行写操作时获得异常。但是,当我尝试使用dll选项启用相同的功能时,我没有得到由主应用程序代码或dll代码分配的内存块上的异常,而根据文档,它应该位于dll代码上 我在WindowsXP和Windows7上都试过了,得到了同样的结果。我检查了很多次,以防输入错误的dll名称,无法在dll上启用完整页面堆 尝试了这两个命令,但均无效:C++ 使用DLL启用gflags完全堆不会';行不通,c++,c,windows,debugging,C++,C,Windows,Debugging,我正在尝试使用调试gflags工具启用带有DLL选项的完整页面堆。这将允许对应用程序启用整页堆,但仅对指定的DLL启用整页堆 当我不使用DLL选项时,它可以正常工作。我能够在任何试图在分配的内存块上进行写操作时获得异常。但是,当我尝试使用dll选项启用相同的功能时,我没有得到由主应用程序代码或dll代码分配的内存块上的异常,而根据文档,它应该位于dll代码上 我在WindowsXP和Windows7上都试过了,得到了同样的结果。我检查了很多次,以防输入错误的dll名称,无法在dll上启用完整页面
gflags -p /enable test_dll1_app.exe /dlls test_dll1.dll
gflags -p /enable test_dll1_app.exe /dlls test_dll1.dll /full
这是我用于测试的代码:
DLL代码:
#define TEST_DLL1_API __declspec(dllexport)
extern "C" TEST_DLL1_API int * fntest_dll1(void)
{
int * value0 = new int [413];
int * value = value0;
for ( int i=0; i < 440; i++ )
*value0++ = i;
return value;
}
typedef int * (*AddFunc)();
int _tmain(int argc, _TCHAR* argv[])
{
HINSTANCE LoadDll;
LoadDll = LoadLibrary(_T("test_dll1.dll"));
if ( LoadDll )
{
AddFunc pfnctFunc;
pfnctFunc = (AddFunc)GetProcAddress(LoadDll, "fntest_dll1");
if ( pfnctFunc )
{
int * value = pfnctFunc();
for ( int i=0; i < 440; i++ )
*value++ = i;
}
}
int * value = new int [413];
for ( int i=0; i < 440; i++ )
*value++ = i;
return 0;
#定义测试_DLL1_API uu declspec(dllexport)
外部“C”测试\u DLL1\u API int*fntest\u DLL1(无效)
{
int*value0=新的int[413];
int*value=value0;
对于(int i=0;i<440;i++)
*值0++=i;
返回值;
}
主要应用程序代码:
#define TEST_DLL1_API __declspec(dllexport)
extern "C" TEST_DLL1_API int * fntest_dll1(void)
{
int * value0 = new int [413];
int * value = value0;
for ( int i=0; i < 440; i++ )
*value0++ = i;
return value;
}
typedef int * (*AddFunc)();
int _tmain(int argc, _TCHAR* argv[])
{
HINSTANCE LoadDll;
LoadDll = LoadLibrary(_T("test_dll1.dll"));
if ( LoadDll )
{
AddFunc pfnctFunc;
pfnctFunc = (AddFunc)GetProcAddress(LoadDll, "fntest_dll1");
if ( pfnctFunc )
{
int * value = pfnctFunc();
for ( int i=0; i < 440; i++ )
*value++ = i;
}
}
int * value = new int [413];
for ( int i=0; i < 440; i++ )
*value++ = i;
return 0;
typedefint*(*AddFunc)();
int _tmain(int argc,_TCHAR*argv[]
{
动态链接库;
LoadDll=LoadLibrary(_T(“test_dll1.dll”);
if(LoadDll)
{
AddFunc pfnctFunc;
pfnctFunc=(AddFunc)GetProcAddress(LoadDll,“fntestdll1”);
如果(pfnctFunc)
{
int*value=pfnctFunc();
对于(int i=0;i<440;i++)
*值+++=i;
}
}
int*value=新的int[413];
对于(int i=0;i<440;i++)
*值+++=i;
返回0;
}
有人能帮我找出我的错误吗。
GB/DLL影响调用Win32 API HeapAlloc的DLL。由于您使用new[]进行分配,因此需要指定的DLL实际上是C运行时(例如msvcrt90.DLL)。我真的不知道如何在每个DLL的基础上工作。确定堆api是否由特定模块调用的唯一方法是对每个调用执行堆栈回溯跟踪,这似乎非常昂贵。是的!现在可以了!由于我拥有这个DLL,所以我能够与C运行时进行静态链接,从而能够对特定的DLL而不是msvcrt90.DLL进行完全检查。非常感谢!!!