다음을 통해 공유


IHostMAlloc::DebugAlloc 메서드

호스트가 힙에서 지정된 양의 메모리를 할당하도록 요청하고 메모리가 할당된 위치를 추가로 추적합니다.

구문

HRESULT DebugAlloc (  
    [in]  SIZE_T  cbSize,
    [in]  EMemoryCriticalLevel dwCriticalLevel,
    [in]  char*   pszFileName,
    [in]  int     iLineNo,
    [out] void**  ppMem  
);  

매개 변수

cbSize
[in] 현재 메모리 할당 요청의 크기(바이트)입니다.

dwCriticalLevel
[in] 할당 실패의 영향을 나타내는 EMemoryCriticalLevel 값 중 하나입니다.

pszFileName
[in] 디버깅 중인 실행 파일의 코드 파일입니다.

iLineNo
[in] 할당이 요청된 pszFileName의 줄 번호입니다.

ppMem
[out] 할당된 메모리에 대한 포인터이거나 요청을 완료할 수 없는 경우 null입니다.

Return Value

HRESULT 설명
S_OK DebugAlloc가 성공적으로 반환되었습니다.
HOST_E_CLRNOTAVAILABLE CLR이 프로세스에 로드되지 않았거나 CLR이 관리 코드를 실행하거나 호출을 성공적으로 처리할 수 없는 상태입니다.
HOST_E_TIMEOUT 호출 시간이 초과되었습니다.
HOST_E_NOT_OWNER 호출자는 잠금을 소유하지 않습니다.
HOST_E_ABANDONED 차단된 스레드 또는 파이버가 이벤트를 기다리는 동안 이벤트가 취소되었습니다.
E_FAIL 알 수 없는 치명적인 오류가 발생했습니다. 메서드가 E_FAIL을 반환하면 CLR은 더 이상 프로세스 내에서 사용할 수 없습니다. 호스팅 메서드에 대한 후속 호출은 HOST_E_CLRNOTAVAILABLE을 반환합니다.
E_OUTOFMEMORY 할당 요청을 완료하는 데 사용할 수 있는 메모리가 부족합니다.

설명

CLR은 IHostMemoryManager::CreateMalloc 메서드를 호출하여 IHostMalloc 인스턴스에 대한 인터페이스 포인터를 가져옵니다. DebugAlloc를 사용하면 런타임에서 디버깅 중에 사용할 코드 파일 정보를 얻을 수 있습니다.

요구 사항

플랫폼:시스템 요구 사항을 참조하세요.

헤더: MSCorEE.h

라이브러리: 리소스로 MSCorEE.dll에 포함됩니다.

.NET Framework 버전: 2.0부터 사용 가능

참고 항목