다음을 통해 공유


_calloc_dbg

디버깅 헤더에 대 한 숫자의 추가 공간이 있는 힙 메모리 블록을 할당 하 고 버퍼 (디버그 버전에만 해당)를 덮어씁니다.

void *_calloc_dbg( 
   size_t num,
   size_t size,
   int blockType,
   const char *filename,
   int linenumber 
);

매개 변수

  • num
    요청한 메모리 블록 수입니다.

  • size
    크기 (바이트) 각 메모리 블록을 요청 합니다.

  • blockType
    요청한 메모리 블록 형식: _CLIENT_BLOCK 또는 _NORMAL_BLOCK.

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

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

  • linenumber
    줄 번호 소스 파일 할당 작업 요청 또는 NULL.

filename 및 linenumber 매개 변수는 에서만 사용할 수 있는 경우 _calloc_dbg 명시적으로 호출 된 나는 _CRTDBG_MAP_ALLOC 전처리기 상수 정의 되었습니다.

반환 값

성공적으로 완료 되 면,이 함수 마지막으로 할당 된 메모리 블록의 사용자 영역에 포인터를 반환, 새 처리기 함수를 호출 하거나 반환 NULL.반환 동작에 대 한 전체 설명은 설명 부분을 참조 하십시오.새 처리기 함수를 사용 하는 방법에 대 한 자세한 내용은 참조 하십시오 있는 calloc 함수입니다.

설명

_calloc_dbg디버그 버전의 것은 calloc 함수.때 _DEBUG 정의 되지 않은 각 호출에 _calloc_dbg 에 대 한 호출을 감소 calloc.둘 다 calloc 및 _calloc_dbg 할당 num 메모리 블록을 기본 힙에서 있지만 _calloc_dbg 몇 개의 디버깅 기능을 제공 합니다.

  • 양쪽의 사용자 부분은 블록이 누수를 테스트 하는 버퍼입니다.

  • 특정 한 할당 형식 추적 하려면 블록 형식 매개 변수입니다.

  • filename/linenumber 할당 요청의 출처를 확인 하는 정보입니다.

_calloc_dbg각 메모리 블록에서 요청 된 것 보다 약간 더 많은 공간이 할당 size.추가 공간 디버그 메모리 블록을 연결 하 고 응용 프로그램을 디버그 헤더 정보를 제공 하 고 버퍼를 덮어쓸 디버그 힙 관리자가 사용 됩니다.블록 할당 될 때 0xCD 값과 사용자 영역 블록을 채워지고 덮어쓰기 버퍼의 각 0xfd로 채워져 있습니다.

_calloc_dbg설정 하는 errno 에 ENOMEM 메모리 할당 오류가 발생 하는 경우. EINVAL(앞에서 설명한 오버 헤드가 포함) 필요한 메모리 용량을 초과 하는 경우 반환 되는 _HEAP_MAXREQ.이 및 기타 오류 코드에 대 한 자세한 내용은 errno, _doserrno, _sys_errlist, _sys_nerr.

메모리 블록 할당, 초기화 및 기본 힙의 디버그 버전에서 관리 하는 방법에 대 한 자세한 내용은 참조 하십시오. 메모리 관리 및 디버그 힙.응용 프로그램의 디버그 빌드에서 해당 디버그 버전을 비교 표준 힙 함수 호출 간의 차이점에 대 한 자세한 내용은 를 디버그 버전 대의 기본 버전을 사용 하 여.

요구 사항

루틴

필수 헤더

_calloc_dbg

<crtdbg.h>

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

예제

// crt_callocd.c
/*
 * This program uses _calloc_dbg to allocate space for
 * 40 long integers. It initializes each element to zero.
 */
#include <stdio.h>
#include <malloc.h>
#include <crtdbg.h>

int main( void )
{
        long *bufferN, *bufferC;

        /* 
         * Call _calloc_dbg to include the filename and line number
         * of our allocation request in the header and also so we can
         * allocate CLIENT type blocks specifically
         */
        bufferN = (long *)_calloc_dbg( 40, sizeof(long), _NORMAL_BLOCK, __FILE__, __LINE__ );
        bufferC = (long *)_calloc_dbg( 40, sizeof(long), _CLIENT_BLOCK, __FILE__, __LINE__ );
        if( bufferN != NULL && bufferC != NULL )
              printf( "Allocated memory successfully\n" );
        else
              printf( "Problem allocating memory\n" );

        /* 
         * _free_dbg must be called to free CLIENT type blocks
         */
        free( bufferN );
        _free_dbg( bufferC, _CLIENT_BLOCK );
}
  

해당 .NET Framework 항목

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

참고 항목

참조

루틴을 디버깅 합니다.

calloc

_malloc_dbg

_DEBUG