Microsoft MVP성태의 닷넷 이야기
VC++: 119. EnumProcesses / EnumProcessModules API 사용 시 주의점 [링크 복사], [링크+제목 복사],
조회: 24613
글쓴 사람
정성태 (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로 조회 시 어떤 모듈도 열거가 안 된다고 합니다.
정성태

... 91  92  93  94  95  96  [97]  98  99  100  101  102  103  104  105  ...
NoWriterDateCnt.TitleFile(s)
11542정성태6/9/201861788개발 환경 구성: 381. Azure Web App 확장 예제 - Remove Custom Headers
11541정성태6/9/201820991개발 환경 구성: 380. Azure Web App 확장 배포 방법 [1]
11540정성태6/9/201821214개발 환경 구성: 379. Azure Web App 확장 예제 제작 [2]
11539정성태6/8/201821653.NET Framework: 763. .NET Core 2.1 - Tiered Compilation 도입파일 다운로드1
11538정성태6/8/201820398.NET Framework: 762. .NET Core 2.1 - 확장 도구(Tools) 관리 [1]
11537정성태6/8/201825519.NET Framework: 761. C# - SmtpClient로 SMTP + SSL/TLS 서버를 이용하는 방법 [5]
11536정성태6/7/201822372.NET Framework: 760. Microsoft Build 2018 - The future of C# 동영상 내용 정리 [1]파일 다운로드1
11535정성태6/7/201824988.NET Framework: 759. C# - System.Span<T> 성능 [1]
11534정성태6/6/201830474.NET Framework: 758. C# 7.2 - Span<T> [6]
11533정성태6/5/201833207.NET Framework: 757. 포인터 형 매개 변수를 갖는 C++ DLL의 함수를 C#에서 호출하는 방법파일 다운로드1
11532정성태6/5/201822561.NET Framework: 756. JSON의 escape sequence 문자 처리 방식
11531정성태6/4/201826796오류 유형: 468. JSON.parse가 허용하지 않는 문자 [9]
11530정성태5/31/201827551.NET Framework: 755. C# 7.2 - 스택에만 생성할 수 있는 값 타입 지원 - "ref struct" [2]파일 다운로드1
11529정성태5/23/201824831.NET Framework: 754. 닷넷의 관리 포인터(Managed Pointer)와 System.TypedReference [6]파일 다운로드1
11528정성태5/17/201824321.NET Framework: 753. C# 7.2 - 3항 연산자에 ref 지원(conditional ref operator) [1]
11527정성태5/17/201822014오류 유형: 467. RDP 로그인 에러 - This could be due to CredSSP encryption oracle remediation.
11526정성태5/16/201821928.NET Framework: 752. C# 7.2 - 메서드의 반환값 및 로컬 변수에 ref readonly 기능 추가파일 다운로드1
11525정성태5/16/201826060.NET Framework: 751. C# 7.2 - 메서드의 매개 변수에 in 변경자 추가 [3]파일 다운로드1
11524정성태5/15/201824962.NET Framework: 750. C# 7.2 - readonly 구조체 [5]파일 다운로드1
11523정성태5/15/201822122.NET Framework: 749. C# - 값 형식의 readonly 인스턴스에 대한 메서드 호출 시 defensive copy 발생 [1]파일 다운로드1
11522정성태5/15/201820613개발 환경 구성: 378. Azure - VM 진단 설정 화면의 "This subscription is not registered with the Microsoft.Insights resource provider."
11521정성태5/15/201818879개발 환경 구성: 377. Azure - 원하는 성능 데이터로 모니터링 대시보드 구성
11520정성태5/12/201821071.NET Framework: 748. C# 7.1 - 참조 어셈블리(Ref Assemblies)
11519정성태5/12/201822871개발 환경 구성: 376. ASP.NET Web Application 프로젝트의 FileSystem 배포(Publish) 시 Before/After Task 설정 방법 [1]
11518정성태5/10/201821126.NET Framework: 747. C# 7.0에서도 부분적으로 가능해진 "타입 추론을 통한 튜플의 변수명 자동 지정"
11517정성태5/10/201819435.NET Framework: 746. Azure runbook 예제 - 6시간 동안 수행 중인 VM을 중지 [1]파일 다운로드1
... 91  92  93  94  95  96  [97]  98  99  100  101  102  103  104  105  ...