GetProcessImageFileNameA 함수(psapi.h)
지정된 프로세스에 대한 실행 파일의 이름을 검색합니다.
통사론
DWORD GetProcessImageFileNameA(
[in] HANDLE hProcess,
[out] LPSTR lpImageFileName,
[in] DWORD nSize
);
매개 변수
[in] hProcess
프로세스에 대한 핸들입니다. 핸들에 PROCESS_QUERY_INFORMATION 또는 PROCESS_QUERY_LIMITED_INFORMATION 액세스 권한이 있어야 합니다. 자세한 내용은 프로세스 보안 및 액세스 권한
Windows Server 2003 및 Windows XP: 핸들에 PROCESS_QUERY_INFORMATION 액세스 권한이 있어야 합니다.
[out] lpImageFileName
실행 파일의 전체 경로를 수신하는 버퍼에 대한 포인터입니다.
[in] nSize
lpImageFileName 버퍼의 크기(문자)입니다.
반환 값
함수가 성공하면 반환 값은 버퍼에 복사된 문자열의 길이를 지정합니다.
함수가 실패하면 반환 값은 0입니다. 확장 오류 정보를 얻으려면 GetLastError호출합니다.
발언
파일 Psapi.dll %windir%\System32 디렉터리에 설치됩니다. 컴퓨터에 이 DLL의 또 다른 복사본이 있는 경우 시스템에서 애플리케이션을 실행할 때 다음과 같은 오류가 발생할 수 있습니다. "프로시저 진입점 GetProcessImageFileName을 동적 링크 라이브러리 PSAPI.DLL 위치할 수 없습니다." 이 문제를 해결하려면 %windir%\System32 디렉터리에 없는 버전을 찾아서 삭제하거나 이름을 바꾼 다음 다시 시작합니다.
GetProcessImageFileName 함수는 드라이브 문자가 아닌 디바이스 형식으로 경로를 반환합니다. 예를 들어 파일 이름 C:\Windows\System32\Ctype.nls는 디바이스 양식에서 다음과 같이 표시됩니다.
\Device\Harddisk0\Partition1\Windows\System32\Ctype.nls
현재 프로세스의 모듈 이름을 검색하려면 NULL 모듈 핸들과 함께 GetModuleFileName 함수를 사용합니다. 현재 프로세스에 대한 핸들을 사용하여 GetProcessImageFileName 함수를 호출하는 것보다 더 효율적입니다.
win32 경로 형식의 원격 프로세스에 대한 기본 실행 모듈의 이름을 검색하려면 QueryFullProcessImageName 함수를 사용합니다.
Windows 7 및 Windows Server 2008 R2부터 Psapi.h는 PSAPI 함수에 대한 버전 번호를 설정합니다. PSAPI 버전 번호는 함수를 호출하는 데 사용되는 이름과 프로그램이 로드해야 하는 라이브러리에 영향을 줍니다.
PSAPI_VERSION 2 이상인 경우 이 함수는 Psapi.h에서 K32GetProcessImageFileName 정의되고 Kernel32.lib 및 Kernel32.dll내보냅니다. PSAPI_VERSION 1이면 이 함수는 Psapi.h의 GetProcessImageFileName 정의되고 Psapi.lib에서 내보내고 Psapi.dll K32GetProcessImageFileName호출하는 래퍼로 내보냅니다.
이전 버전의 Windows 및 Windows 7 이상 버전에서 실행해야 하는 프로그램은 항상 이 함수를 GetProcessImageFileName호출해야 합니다. 기호의 올바른 해상도를 보장하려면 TARGETLIBS 매크로에 Psapi.lib를 추가하고 -DPSAPI_VERSION=1사용하여 프로그램을 컴파일합니다. 런타임 동적 연결을 사용하려면 Psapi.dll로드합니다.
메모
psapi.h 헤더는 GETProcessImageFileName을 유니코드 전처리기 상수의 정의에 따라 이 함수의 ANSI 또는 유니코드 버전을 자동으로 선택하는 별칭으로 정의합니다. 인코딩 중립 별칭을 인코딩 중립이 아닌 코드와 혼합하면 컴파일 또는 런타임 오류가 발생하는 불일치가 발생할 수 있습니다. 자세한 내용은 함수 프로토타입대한
요구 사항
요구 | 값 |
---|---|
지원되는 최소 클라이언트 | Windows XP [데스크톱 앱만 해당] |
지원되는 최소 서버 | Windows Server 2003 [데스크톱 앱만 해당] |
대상 플랫폼 | Windows |
헤더 | psapi.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 |
참고 항목
QueryFullProcessImageName