Microsoft MVP성태의 닷넷 이야기
VC++: 119. EnumProcesses / EnumProcessModules API 사용 시 주의점 [링크 복사], [링크+제목 복사],
조회: 24556
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

EnumProcesses / EnumProcessModules API 사용 시 주의점

관련 도움말을 보면,

EnumProcessModules
; https://docs.microsoft.com/en-us/windows/win32/api/psapi/nf-psapi-enumprocessmodules

분명히 지원 운영체제가 Windows XP/2003 이상이라고 나옵니다. 하지만 실제로 사용해 보면, Windows 7/2008 R2 이상에서만 해당 API들이 (실행 시) 정상적으로 import됩니다.

그 이유는, 최근의 Windows SDK에 있는 psapi.h 파일이 다음과 같이 매크로 정의로 "K32..." API로 우회하고 있기 때문입니다.

#define EnumProcesses               K32EnumProcesses
#define EnumProcessModules          K32EnumProcessModules

원래 EnumProcesses / EnumProcessModules API들은 psapi.dll에 있는데, K32... API들은 kernel32.dll로 옮겨졌습니다. 즉, Windows XP/2003/Vista/2008까지는 psapi.dll에 포함되어 있지만 그 이후의 버전에는 psapi.dll의 것들은 껍데기이고 kernel32.dll에 있는 API로 우회하도록 되어 있습니다.

아울러, 최근의 Windows SDK들은 psapi.dll의 껍데기를 호출하지 않고 곧바로 kernel32.dll에 있는 K32EnumProcesses / K32EnumProcessModules API들을 호출할 수 있도록 저렇게 macro 정의를 하고 있는 것입니다.




그렇기 때문에 Visual Studio 구 버전에서 빌드하면 API를 담고 있는 DLL/EXE들이 잘 사용이 되는 반면, 동일한 소스 코드를 최신 버전의 Visual Studio에서 빌드하면 해당 DLL/EXE는 다음과 같은 식으로 K32... 류의 API와 바인딩되어 있기 때문에,

enumprocessmodules_1.png

XP/2003/Vista/2008에서는 실행할 수 없게 되는 것입니다.

이를 해결하려면, 명시적으로 EnumProcesses 이름 그대로 사용해야 하는데 방법은 PSAPI_VERSION 버전을 낮춰주면 됩니다.

#undef PSAPI_VERSION
#define PSAPI_VERSION 1

#include <Psapi.h>
#pragma comment(lib, "psapi.lib")

참고로, 이런 식으로 매핑된 API들이 몇 개 있기 때문에 사용에 주의를 요합니다.

#if (PSAPI_VERSION > 1)
#define EnumProcesses               K32EnumProcesses
#define EnumProcessModules          K32EnumProcessModules
#define EnumProcessModulesEx        K32EnumProcessModulesEx
#define GetModuleBaseNameA          K32GetModuleBaseNameA
#define GetModuleBaseNameW          K32GetModuleBaseNameW
#define GetModuleFileNameExA        K32GetModuleFileNameExA
#define GetModuleFileNameExW        K32GetModuleFileNameExW
#define GetModuleInformation        K32GetModuleInformation
#define EmptyWorkingSet             K32EmptyWorkingSet
#define QueryWorkingSet             K32QueryWorkingSet
#define QueryWorkingSetEx           K32QueryWorkingSetEx
#define InitializeProcessForWsWatch K32InitializeProcessForWsWatch
#define GetWsChanges                K32GetWsChanges
#define GetWsChangesEx              K32GetWsChangesEx
#define GetMappedFileNameW          K32GetMappedFileNameW
#define GetMappedFileNameA          K32GetMappedFileNameA
#define EnumDeviceDrivers           K32EnumDeviceDrivers
#define GetDeviceDriverBaseNameA    K32GetDeviceDriverBaseNameA
#define GetDeviceDriverBaseNameW    K32GetDeviceDriverBaseNameW
#define GetDeviceDriverFileNameA    K32GetDeviceDriverFileNameA
#define GetDeviceDriverFileNameW    K32GetDeviceDriverFileNameW
#define GetProcessMemoryInfo        K32GetProcessMemoryInfo
#define GetPerformanceInfo          K32GetPerformanceInfo
#define EnumPageFilesW              K32EnumPageFilesW
#define EnumPageFilesA              K32EnumPageFilesA
#define GetProcessImageFileNameA    K32GetProcessImageFileNameA
#define GetProcessImageFileNameW    K32GetProcessImageFileNameW
#endif




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 7/13/2021]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 



2019-03-25 11시35분
Listing Loaded Shared Objects in Linux
; http://syprog.blogspot.com/2011/12/listing-loaded-shared-objects-in-linux.html

--------------------------------------------------

Why does Enum­Process­Modules report no modules on a process that was created suspended?
; https://devblogs.microsoft.com/oldnewthing/20250526-00/?p=111218

suspend 상태로 시작한 프로세스를 EnumProcessModules로 조회 시 어떤 모듈도 열거가 안 된다고 합니다.
정성태

... 31  32  33  [34]  35  36  37  38  39  40  41  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
13123정성태9/8/202217199.NET Framework: 2046. C# 11 - 멤버(속성/필드)에 지정할 수 있는 required 예약어 추가
13122정성태8/26/202217583.NET Framework: 2045. C# 11 - 메서드 매개 변수에 대한 nameof 지원
13121정성태8/23/202213096C/C++: 157. Golang - 구조체의 slice 필드를 Reflection을 이용해 변경하는 방법
13120정성태8/19/202217670Windows: 209. Windows NT Service에서 UI를 다루는 방법 [3]
13119정성태8/18/202216725.NET Framework: 2044. .NET Core/5+ 프로젝트에서 참조 DLL이 보관된 공통 디렉터리를 지정하는 방법
13118정성태8/18/202213498.NET Framework: 2043. WPF Color의 기본 색 영역은 (sRGB가 아닌) scRGB [2]
13117정성태8/17/202218008.NET Framework: 2042. C# 11 - 파일 범위 내에서 유효한 타입 정의 (File-local types)파일 다운로드1
13116정성태8/4/202218376.NET Framework: 2041. C# - Socket.Close 시 Socket.Receive 메서드에서 예외가 발생하는 문제파일 다운로드1
13115정성태8/3/202219061.NET Framework: 2040. C# - ValueTask와 Task의 성능 비교 [1]파일 다운로드1
13114정성태8/2/202218769.NET Framework: 2039. C# - Task와 비교해 본 ValueTask 사용법파일 다운로드1
13113정성태7/31/202218423.NET Framework: 2038. C# 11 - Span 타입에 대한 패턴 매칭 (Pattern matching on ReadOnlySpan<char>)
13112정성태7/30/202219196.NET Framework: 2037. C# 11 - 목록 패턴(List patterns) [1]파일 다운로드1
13111정성태7/29/202218665.NET Framework: 2036. C# 11 - IntPtr/UIntPtr과 nint/nuint의 통합파일 다운로드1
13110정성태7/27/202217892.NET Framework: 2035. C# 11 - 새로운 연산자 ">>>" (Unsigned Right Shift)파일 다운로드1
13109정성태7/27/202220033VS.NET IDE: 177. 비주얼 스튜디오 2022를 이용한 (소스 코드가 없는) 닷넷 모듈 디버깅 - "외부 원본(External Sources)" [1]
13108정성태7/26/202217194Linux: 53. container에 실행 중인 Golang 프로세스를 디버깅하는 방법 [1]
13107정성태7/25/202216006Linux: 52. Debian/Ubuntu 계열의 docker container에서 자주 설치하게 되는 명령어
13106정성태7/24/202214939오류 유형: 819. 닷넷 6 프로젝트의 "Conditional compilation symbols" 기본값 오류
13105정성태7/23/202218298.NET Framework: 2034. .NET Core/5+ 환경에서 (프로젝트가 아닌) C# 코드 파일을 입력으로 컴파일하는 방법 - 두 번째 이야기 [1]
13104정성태7/23/202221880Linux: 51. WSL - init에서 systemd로 전환하는 방법
13103정성태7/22/202217204오류 유형: 818. WSL - systemd-genie와 관련한 2가지(systemd-remount-fs.service, multipathd.socket) 에러
13102정성태7/19/202216786.NET Framework: 2033. .NET Core/5+에서는 구할 수 없는 HttpRuntime.AppDomainAppId
13101정성태7/15/202230336도서: 시작하세요! C# 10 프로그래밍
13100정성태7/15/202218874.NET Framework: 2032. C# 11 - shift 연산자 재정의에 대한 제약 완화 (Relaxing Shift Operator)
13099정성태7/14/202218195.NET Framework: 2031. C# 11 - 사용자 정의 checked 연산자파일 다운로드1
13098정성태7/13/202215894개발 환경 구성: 647. Azure - scale-out 상태의 App Service에서 특정 인스턴스에 요청을 보내는 방법 [1]
... 31  32  33  [34]  35  36  37  38  39  40  41  42  43  44  45  ...