_realloc_dbg
지정 된 블록의 힙 메모리를 이동 하거나 (디버그 버전에만 해당) 블록의 크기를 조정 하 여 다시 할당 합니다.
void *_realloc_dbg(
void *userData,
size_t newSize,
int blockType,
const char *filename,
int linenumber
);
매개 변수
userData
이전에 할당 된 메모리 블록에 대 한 포인터입니다.newSize
재할당 블록 (바이트 단위) 크기를 요청 했습니다.blockType
재할당 블록 유형을 요청 했습니다: _CLIENT_BLOCK 또는 _NORMAL_BLOCK.filename
요청 된 소스 파일의 이름에 대 한 포인터를 realloc 작업 또는 NULL입니다.linenumber
줄 번호 소스 파일에서 위치를 realloc 요청 된 또는 NULL 작업을 했습니다.
filename 및 linenumber 매개 변수는 에서만 사용할 수 있는 경우 _realloc_dbg 명시적으로 호출 된 나는 _CRTDBG_MAP_ALLOC 전처리기 상수 정의 되었습니다.
반환 값
성공적으로 완료가이 함수를 재할당된 메모리 블록의 사용자 영역에 포인터를 반환, 새 처리기 함수를 호출 또는 NULL을 반환 합니다.반환 동작에 대 한 전체 설명은 아래 설명 부분을 참조 하십시오.새 처리기 함수를 사용 하는 방법에 대 한 자세한 내용은 참조 하십시오 있는 realloc 함수입니다.
설명
_realloc_dbg디버그 버전의 것은 realloc 함수.때 _DEBUG 정의 되지 않은 각 호출에 _realloc_dbg 에 대 한 호출을 감소 realloc.둘 다 realloc 및 _realloc_dbg 메모리 블록을 기본 힙에서 할당 하지만 _realloc_dbg 몇 개의 디버깅 기능을 사용할 수: 버퍼 누수에 대 한 특정 한 할당 형식 추적 하는 블록 형식 매개 변수를 테스트 하는 블록의 사용자 부분에 대 한 filename/linenumber 할당 요청의 출처를 확인 하는 정보.
_realloc_dbg지정 된 메모리 블록은 요청 된 것 보다 약간 더 많은 공간을 다시 할당 newSize.newSize원래 할당 된 메모리 블록의 크기 보다 큰지 또는 작은지 될 수 있습니다.추가 공간 디버그 메모리 블록을 연결 하 고 응용 프로그램을 디버그 헤더 정보를 제공 하 고 버퍼를 덮어쓸 디버그 힙 관리자가 사용 됩니다.재할당 된 원래 메모리 블록 힙에 있는 다른 위치로 이동에 따라 메모리 블록의 크기를 변경 하면 발생할 수 있습니다.메모리 블록을 이동 하면 원래 블록의 내용은 덮어씁니다.
_realloc_dbg설정 하는 errno 에 ENOMEM 메모리 할당 오류가 발생 하는 경우 또는 (앞에서 설명한 오버 헤드가 포함) 필요한 메모리 용량을 초과 하는 경우 _HEAP_MAXREQ.이 및 기타 오류 코드에 대 한 자세한 내용은 errno, _doserrno, _sys_errlist, _sys_nerr.
메모리 블록 할당, 초기화 및 기본 힙의 디버그 버전에서 관리 하는 방법에 대 한 자세한 내용은 참조 하십시오. 메모리 관리 및 디버그 힙.할당 블록 종류 및 사용 방법에 대 한 자세한 내용은 의 디버그 힙의 블록 형식.응용 프로그램의 디버그 빌드를 호출 하는 표준 힙 함수 및 해당 디버그 버전 간의 차이점에 대 한 자세한 내용은 를 디버그 버전 대의 기본 버전을 사용 하 여.
요구 사항
루틴 |
필수 헤더 |
---|---|
_realloc_dbg |
<crtdbg.h> |
더 많은 호환성 정보를 참조 하십시오. 호환성 소개에서 합니다.
라이브러리
디버그 버전의 C 런타임 라이브러리 만 합니다.
예제
예에서 볼 수 있는 _msize_dbg 항목입니다.
해당 .NET Framework 항목
해당 사항 없음. 표준 C 함수를 호출할 수 있습니다 PInvoke. 자세한 내용은 플랫폼 호출 예제.