다음을 통해 공유


_aligned_offset_malloc_dbg

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

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 를 설정 하 고 errno 에 EINVAL.

메모리 블록 할당, 초기화 및 기본 힙의 디버그 버전에서 관리 하는 방법에 대 한 자세한 내용은 참조 하십시오. 메모리 관리 및 디버그 힙.

할당 블록 종류 및 사용 방법에 대 한 자세한 내용은 의 디버그 힙의 블록 형식.

요구 사항

루틴

필수 헤더

_aligned_offset_malloc_dbg

<crtdbg.h>

더 많은 호환성 정보를 참조 하십시오. 호환성 소개에서 합니다.

라이브러리

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

해당 .NET Framework 항목

해당 사항 없음. 표준 C 함수를 호출할 수 있습니다 PInvoke. 자세한 내용은 플랫폼 호출 예제.

참고 항목

참조

루틴을 디버깅 합니다.