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에서 내보내고 K32GetProcessImageFileName을 호출하는 래퍼로 Psapi.dll.

이전 버전의 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

추가 정보

PSAPI 함수

프로세스 정보

QueryFullProcessImageName