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부터 사용 가능
참고 항목
GitHub에서 Microsoft와 공동 작업
이 콘텐츠의 원본은 GitHub에서 찾을 수 있으며, 여기서 문제와 끌어오기 요청을 만들고 검토할 수도 있습니다. 자세한 내용은 참여자 가이드를 참조하세요.
.NET