Member 13010616 Ответов: 1

Как мне это исправить? Hproc не объявлен в этой области?


#include <iostream>
#include <windows.h>
#include "psapi.h"

using namespace std;
DWORD GetModuleBase(HANDLE hProc, string &sModuleName)
{
   HMODULE *hModules;
   char szBuf[50];
   DWORD cModules;
   DWORD dwBase = -1;
   //------

   EnumProcessModules(hProc, hModules, 0, &cModules);
   hModules = new HMODULE[cModules/sizeof(HMODULE)];

   if(EnumProcessModules(hProc, hModules, cModules/sizeof(HMODULE), &cModules)) {
      for(int i = 0; i < cModules/sizeof(HMODULE); i++) {
         if(GetModuleBaseName(hProc, hModules[i], szBuf, sizeof(szBuf))) {
            if(sModuleName.compare(szBuf) == 0) {
               dwBase = (DWORD)hModules[i];
               break;
            }
         }
      }
   }

   delete[] hModules;

   return dwBase;
}

int main()
{
    ---------------->>>>GetModuleBase(hProc, string("winmine.exe"));
}


Что я уже пробовал:

#include <iostream>
#include <windows.h>
#include "psapi.h"

using namespace std;
DWORD GetModuleBase(HANDLE hProc, string &sModuleName)
{
   HMODULE *hModules;
   char szBuf[50];
   DWORD cModules;
   DWORD dwBase = -1;
   //------

   EnumProcessModules(hProc, hModules, 0, &cModules);
   hModules = new HMODULE[cModules/sizeof(HMODULE)];

   if(EnumProcessModules(hProc, hModules, cModules/sizeof(HMODULE), &cModules)) {
      for(int i = 0; i < cModules/sizeof(HMODULE); i++) {
         if(GetModuleBaseName(hProc, hModules[i], szBuf, sizeof(szBuf))) {
            if(sModuleName.compare(szBuf) == 0) {
               dwBase = (DWORD)hModules[i];
               break;
            }
         }
      }
   }

   delete[] hModules;

   return dwBase;
}

int main()
{
    -------------->>>>GetModuleBase(hProc, string("winmine.exe"));
}

1 Ответов

Рейтинг:
6

Rick York

Ну и где же объявлен hProc? Единственное, что я вижу, - это аргумент GetModuleBase (), и это не входит в область действия main. Вам нужно объявить его в main, чтобы он был доступен в main.

Еще одна вещь, ради отладки мне нравится использовать временную переменную, когда я вижу повторяющееся выражение. Я также думаю, что вызов переменных cModules вводит в заблуждение. На самом деле это объем памяти в байтах, необходимый для хранения всех данных. Я бы сделал следующее :

DWORD memoryNeeded = 0;
EnumProcessModules( hProc, hModules, 0, &memoryNeeded );
DWORD moduleCount = memoryNeeded / sizeof( HMODULE );
а затем я бы использовал переменную moduleCount в более позднем коде.


Rick York

Одно уточнение - hProc может быть объявлен глобально, но функция принимает его в качестве аргумента, поэтому может быть запутанным иметь как глобальную переменную, так и аргумент функции с одним и тем же именем.