다음을 통해 공유


EnumProcessModulesEx 함수(psapi.h)

지정된 필터 조건을 충족하는 지정된 프로세스의 각 모듈에 대한 핸들을 검색합니다.

구문

BOOL EnumProcessModulesEx(
  [in]  HANDLE  hProcess,
  [out] HMODULE *lphModule,
  [in]  DWORD   cb,
  [out] LPDWORD lpcbNeeded,
  [in]  DWORD   dwFilterFlag
);

매개 변수

[in] hProcess

프로세스에 대한 핸들입니다.

[out] lphModule

모듈 핸들 목록을 수신하는 배열입니다.

[in] cb

lphModule 배열의 크기(바이트)입니다.

[out] lpcbNeeded

lphModule 배열에 모든 모듈 핸들을 저장하는 데 필요한 바이트 수입니다.

[in] dwFilterFlag

필터 조건입니다. 이 매개 변수는 다음 값 중 하나일 수 있습니다.

의미
LIST_MODULES_32BIT
0x01
32비트 모듈을 나열합니다.
LIST_MODULES_64BIT
0x02
64비트 모듈을 나열합니다.
LIST_MODULES_ALL
0x03
모든 모듈을 나열합니다.
LIST_MODULES_DEFAULT
0x0
기본 동작을 사용합니다.

반환 값

함수가 성공하면 반환 값이 0이 아닙니다.

함수가 실패하면 반환 값은 0입니다. 확장 오류 정보를 가져오려면 GetLastError를 호출합니다.

설명

EnumProcessModulesEx 함수는 주로 디버거 및 다른 프로세스에서 모듈 정보를 추출해야 하는 유사한 애플리케이션에서 사용하도록 설계되었습니다. 대상 프로세스의 모듈 목록이 손상되었거나 아직 초기화되지 않았거나 DLL이 로드되거나 언로드된 결과로 함수 호출 중에 모듈 목록이 변경되면 EnumProcessModulesEx 가 실패하거나 잘못된 정보를 반환할 수 있습니다.

이 함수는 주로 64비트 애플리케이션을 위한 것입니다. WOW64에서 실행되는 32비트 애플리케이션에서 함수를 호출하면 dwFilterFlag 옵션이 무시되고 함수는 EnumProcessModules 함수와 동일한 결과를 제공합니다.

EnumProcessModulesEx를 호출할 때 프로세스에 있을 모듈 수를 예측하기 어렵기 때문에 HMODULE 값의 큰 배열을 지정하는 것이 좋습니다. lphModule 배열이 너무 작아 프로세스에 대한 모든 모듈 핸들을 보유할 수 없는지 확인하려면 lpcbNeeded에서 반환된 값을 cb에 지정된 값과 비교합니다. lpcbNeededcb보다 크면 배열의 크기를 늘리고 EnumProcessModulesEx를 다시 호출합니다.

EnumProcessModulesEx 호출로 열거된 모듈 수를 확인하려면 lpcbNeeded 매개 변수의 결과 값을 로 sizeof(HMODULE)나눕니다.

EnumProcessModulesEx 함수는 LOAD_LIBRARY_AS_DATAFILE 플래그와 함께 로드된 모듈에 대한 핸들을 검색하지 않습니다. 자세한 내용은 LoadLibraryEx를 참조하세요.

이 함수에서 반환된 핸들에 대해 CloseHandle 을 호출하지 마세요. 정보는 스냅샷 제공되므로 해제할 리소스가 없습니다.

지정된 프로세스와 이러한 프로세스에서 사용하는 힙, 모듈 및 스레드의 스냅샷 사용하려면 CreateToolhelp32Snapshot 함수를 사용합니다.

Windows 7 및 Windows Server 2008 R2부터 Psapi.h는 PSAPI 함수에 대한 버전 번호를 설정합니다. PSAPI 버전 번호는 함수를 호출하는 데 사용되는 이름과 프로그램이 로드해야 하는 라이브러리에 영향을 줍니다.

PSAPI_VERSION 2 이상인 경우 이 함수는 Psapi.h에서 K32EnumProcessModulesEx 로 정의되고 Kernel32.lib 및 Kernel32.dll 내보냅니다. PSAPI_VERSION 1이면 이 함수는 Psapi.h에서 EnumProcessModulesEx 로 정의되고 Psapi.lib에서 내보내고 K32EnumProcessModulesEx를 호출하는 래퍼로 Psapi.dll.

이전 버전의 Windows 및 Windows 7 이상 버전에서 실행해야 하는 프로그램은 항상 이 함수를 EnumProcessModulesEx로 호출해야 합니다. 기호의 올바른 해상도를 보장하려면 TargetLIBS 매크로에 Psapi.lib를 추가하고 –DPSAPI_VERSION=1로 프로그램을 컴파일합니다. 런타임 동적 연결을 사용하려면 Psapi.dll 로드합니다.

요구 사항

요구 사항
지원되는 최소 클라이언트 Windows Vista [데스크톱 앱만 해당]
지원되는 최소 서버 Windows Server 2008 [데스크톱 앱만 해당]
대상 플랫폼 Windows
헤더 psapi.h(Windows.h 포함)
라이브러리 Windows 7 및 Windows Server 2008 R2의 Kernel32.lib; Windows 7 및 Windows Server 2008 R2의 Psapi.lib(PSAPI_VERSION=1인 경우) Windows Server 2008, Windows Vista, Windows Server 2003 및 Windows XP의 Psapi.lib
DLL Windows 7 및 Windows Server 2008 R2의 Kernel32.dll Windows 7 및 Windows Server 2008 R2에서 Psapi.dll(PSAPI_VERSION=1인 경우) Windows Server 2008, Windows Vista, Windows Server 2003 및 Windows XP의 Psapi.dll

추가 정보

CreateToolhelp32Snapshot

EnumProcesses

모듈 정보

PSAPI 함수