C++ 使用DLL启用gflags完全堆不会';行不通

C++ 使用DLL启用gflags完全堆不会';行不通,c++,c,windows,debugging,C++,C,Windows,Debugging,我正在尝试使用调试gflags工具启用带有DLL选项的完整页面堆。这将允许对应用程序启用整页堆,但仅对指定的DLL启用整页堆 当我不使用DLL选项时,它可以正常工作。我能够在任何试图在分配的内存块上进行写操作时获得异常。但是,当我尝试使用dll选项启用相同的功能时,我没有得到由主应用程序代码或dll代码分配的内存块上的异常,而根据文档,它应该位于dll代码上 我在WindowsXP和Windows7上都试过了,得到了同样的结果。我检查了很多次,以防输入错误的dll名称,无法在dll上启用完整页面

我正在尝试使用调试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进行完全检查。非常感谢!!!