_aligned_offset_malloc_dbg

 

Visual Studio 2017 에 대한 최신 설명서는 Visual Studio 2017 설명서를 참조하세요.

(디버그 버전에만 해당)는 지정 된 정렬 경계에서 메모리를 할당합니다.

void * _aligned_offset_malloc_dbg(  
   size_t size,   
   size_t alignment,   
   size_t offset,  
   const char *filename,  
   int linenumber   
);  

매개 변수

[in] size
요청된 메모리 할당 크기입니다.

[in] alignment
맞춤 값으로 2의 정수 거듭제곱이어야 합니다.

[in] offset
맞춤을 강제하는 메모리 할당으로의 오프셋입니다.

[in] filename
할당 작업 또는 NULL을 요청한 소스 파일의 이름에 대한 포인터입니다.

[in] linenumber
할당 작업이 요청되었거나 NULL인 소스 파일의 줄 번호입니다.

할당된 메모리 블록에 대한 포인터로 작업 실패 시 NULL입니다.

_aligned_offset_malloc_dbg디버그 버전이 _aligned_offset_malloc 함수입니다. 때 _DEBUG 정의 되지 않은 각 호출에 _aligned_offset_malloc_dbg 에 대 한 호출으로 줄어듭니다 _aligned_offset_malloc합니다. 둘 다 _aligned_offset_malloc_aligned_offset_malloc_dbg 기본 힙에서 메모리 블록을 할당 하지만 _aligned_offset_malloc_dbg 여러 디버깅 기능을 제공: 누수 테스트, 블록 형식 매개 변수로 특정 할당 형식 추적에 블록의 사용자 부분 양쪽에 버퍼 및 filename / linenumber 정보로 할당 요청의 원점을 확인 하 합니다.

_aligned_offset_malloc_dbg는 요청된 size보다 약간 큰 공간의 메모리 블록을 할당합니다. 디버그 힙 관리자는 추가 공간을 사용하여 디버그 메모리 블록을 연결하고 응용 프로그램에 디버그 헤더 정보를 제공하고 버퍼를 덮어씁니다. 블록이 할당되면 블록의 사용자 부분은 값 0xCD로 채워지고 각 덮어쓰기 버퍼는 0xFD로 채워집니다.

_aligned_offset_malloc_dbg맞춤; 중첩된 된 요소에 필요한 경우에 유용 예를 들어 다음과 같이 중첩 된 클래스에 맞춤 필요 했습니다.

_aligned_offset_malloc_dbg에 따라 malloc; 자세한 내용은 참조 malloc합니다.

이 함수는 메모리 할당에 실패한 경우 또는 요청된 크기가 errno보다 큰 경우 ENOMEM_HEAP_MAXREQ으로 설정합니다. 에 대 한 자세한 내용은 errno, 참조 errno, _doserrno, _sys_errlist 및 _sys_nerr합니다. 또한 _aligned_offset_malloc는 매개 변수의 유효성을 검사합니다. 경우 alignment 2의 거듭제곱이 아닌 경우 offset 보다 크거나 같지 size 0이 아닌 경우이 함수는 잘못 된 매개 변수 처리기를 호출에 설명 된 대로 및 매개 변수 유효성 검사합니다. 계속해서 실행하도록 허용한 경우 이 함수는 NULL을 반환하고 errnoEINVAL로 설정합니다.

기본 힙의 디버그 버전에서 메모리 블록을 할당, 초기화 및 관리하는 방법에 대한 자세한 내용은 CRT Debug Heap Details를 참조하세요.

할당 블록 형식 및 사용 하는 방법에 대 한 정보를 참조 하십시오. 디버그 힙의 블록 형식합니다.

루틴필수 헤더
_aligned_offset_malloc_dbg<crtdbg.h>

호환성에 대한 자세한 내용은 소개 단원의 Compatibility 을 참조하세요.

디버그 버전의 C 런타임 라이브러리 만 합니다.

해당 사항 없음. 표준 C 함수를 호출하려면 PInvoke를 사용합니다. 자세한 내용은 플랫폼 호출 예제를 참조하십시오.

디버그 루틴

표시: