다음을 통해 공유


_aligned_malloc_dbg

디버깅 헤더 및 덮어쓰기 버퍼(디버그 버전에만 해당)에 대한 추가 공간을 사용하여 지정된 맞춤 경계에 메모리를 할당합니다.

구문

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

매개 변수

size
요청된 메모리 할당의 크기입니다.

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

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

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

반환 값

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

설명

_aligned_malloc_dbg 는 함수의 디버그 버전입니다 _aligned_malloc . 정의되지 않은 경우 _DEBUG 각 호출 _aligned_malloc_dbg 이 호출로 _aligned_malloc줄어듭니다. _aligned_malloc_aligned_malloc_dbg 둘 다 기본 힙에서 메모리 블록을 할당하지만 _aligned_malloc_dbg는 여러 디버깅 특징, 즉 누수를 테스트하기 위한 블록의 사용자 부분 양쪽에서의 버퍼 및 할당 요청의 원점을 확인하기 위한 filename/linenumber 정보를 제공합니다. 블록 형식 매개 변수를 사용하여 특정 할당 유형을 추적하는 것은 정렬된 할당에 대해 지원되는 디버그 기능이 아닙니다. 정렬된 할당은 블록 형식으로 _NORMAL_BLOCK 표시됩니다.

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

메모리 할당에 실패한 경우 또는 필요한 메모리 양(앞에서 언급한 오버헤드 포함)이 _aligned_malloc_dbg를 초과한 경우 errnoENOMEM_HEAP_MAXREQ으로 설정합니다. 이 코드 및 기타 오류 코드에 대한 자세한 내용은 , _doserrno, _sys_errlist_sys_nerr를 참조하세요errno. 또한 _aligned_malloc_dbg는 매개 변수의 유효성을 검사합니다. 2의 힘이 아니거나 size 0인 경우 alignment 이 함수는 매개 변수 유효성 검사에 설명된 대로 잘못된 매개 변수 처리기를 호출합니다. 계속해서 실행하도록 허용한 경우 이 함수는 NULL을 반환하고 errnoEINVAL로 설정합니다.

기본 힙의 디버그 버전에서 메모리 블록을 할당, 초기화 및 관리하는 방법에 대한 자세한 내용은 CRT 디버그 힙 세부 정보를 참조 하세요. 할당 블록 형식 및 사용 방법에 대한 자세한 내용은 디버그 힙의 블록 유형을 참조 하세요. 표준 힙 함수와 해당 디버그 버전 간의 차이점에 대한 자세한 내용은 힙 할당 함수의 디버그 버전을 참조 하세요.

요구 사항

루틴에서 반환된 값 필수 헤더
_aligned_malloc_dbg <crtdbg.h>

호환성에 대한 자세한 내용은 호환성을 참조하세요.

라이브러리

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

참고 항목

디버그 루틴