_expand_dbg
블록을 확장 또는 축소하여 힙 메모리에 지정된 블록 크기 조정합니다. (디버그 버전에만 해당)
void *_expand_dbg(
void *userData,
size_t newSize,
int blockType,
const char *filename,
int linenumber
);
매개 변수
userData
이전에 할당 된 메모리 블록에 대 한 포인터입니다.newSize
블록 (바이트 단위)의 새로운 크기를 다시 요청합니다.blockType
크기가 조정된 블록의 형식을 요청합니다: _CLIENT_BLOCK 또는 _NORMAL_BLOCK .filename
NULL 또는 확장 작업을 요청하는 소스 파일의 이름에 대한 포인터입니다.linenumber
확장 작업 요청하는 소스 파일의 줄 번호 또는 NULL입니다.
filename 및 linenumber 매개 변수는 _expand_dbg 가 명시적으로 호출되거나 _CRTDBG_MAP_ALLOC 전처리기 상수가 정의되었을 경우, 사용할 수 있습니다.
반환 값
성공적으로 완료하면, _expand_dbg 는 리사이즈된 메모리 블록에 대한 포인터를 반환합니다. 메모리를 이동하지 않으므로 주소는 해당 사용자데이터처럼 같습니다. 오류가 발생 하거나 블록이 요청된 크기만큼 확장할 수 없을 경우, NULL 을 반환합니다. 오류가 발생 하면 errno 는 실패의 본질에 대한 운영 체제의 정보를 사용합니다. errno에 대한 자세한 내용은 errno, _doserrno, _sys_errlist 및 _sys_nerr을 참조하십시오.
설명
_expand_dbg 함수는 _확장 함수의 디버그 버전입니다. _DEBUG를 정의 하지 않으면, _expand_dbg 의 각 호출은 _expand 의 호출에 감소됩니다. _expand 및 _expand_dbg 는 모두 기본 힙에서 블록 메모리를 리사이즈하지만 _expand_dbg 은 몇 개의 디버깅 기능을 수용합니다: 특정 유형의 할당을 추적하는 누출 블록 타입 파라미터를 테스트하는 블록의 사용자 부분의 양쪽에 버퍼 및 할당 요청의 출처를 확인하기 위한 filename / linenumber 정보.
_expand_dbg은 요청된 newSize 보다 조금 더 많은 공간을 사용하여 지정된 메모리 블록을 리사이즈합니다. newSize는 원래 할당된 메모리 블록의 크기보다 작거나 클 수 있습니다. 추가 공간은 디버그 힙 관리자가 디버그 메모리 블록을 연결하고 디버그 헤더 정보를 사용하여 응용 프로그램을 제공하고 버퍼를 덮어쓰는데 사용됩니다. 크기 조정은 원래 메모리 블록을 축소 하거나 확장하여 수행됩니다. _expand_dbg은 _realloc_dbg 함수와 마찬가지로 메모리 블록을 이동하지 않습니다.
newSize 가 원래 블록 크기보다 클 떄, 메모리 블록을 확장합니다. 확장 하는 동안 , 메모리 블록의 요청 된 크기에 맞게 확장할 수 없는 경우에 NULL 이 반환됩니다. newSize 가 원본 블록 크기보다 작을 때, 메모리 블록은 새로운 크기를 얻을 때까지 수축됩니다.
기본 힙의 디버그 버전에서 메모리 블록이 어떻게 할당되고 초기화되고 관리되는지에 대한 자세한 내용은 CRT 디버그 힙 정보 를 참조하십시오. 할당 블록 종류 및 사용 방법에 대한 더 자세한 내용은 디버그 힙의 블록 종류을 참조하십시오. 호출 표준 힙 함수 및 응용 프로그램의 디버그 빌드에서 디버그 버전의 차이점에 대한 내용은 힙 할당 함수의 디버그 버전를 참조하십시오.
이 함수는 해당 매개 변수의 유효성을 검사합니다. memblock 이 null 포인터이거나 _HEAP_MAXREQ 보다 크기가 큰 경우, 매개 변수 유효성 검사에 설명 된 대로 이 함수는 잘못 된 매개 변수 처리기를 호출합니다. 계속해서 실행하도록 허용된 경우, 이러한 함수는 errno 를 EINVAL 로 설정하고 NULL을 반환합니다.
요구 사항
루틴 |
필수 헤더 |
---|---|
_expand_dbg |
<crtdbg.h> |
호환성 정보에 대한 자세한 내용은 호환성을 참조하십시오.
라이브러리
C 런타임 라이브러리 의 유일한 디버그 버전입니다.
예제
// crt_expand_dbg.c
//
// This program allocates a block of memory using _malloc_dbg
// and then calls _msize_dbg to display the size of that block.
// Next, it uses _expand_dbg to expand the amount of
// memory used by the buffer and then calls _msize_dbg again to
// display the new amount of memory allocated to the buffer.
//
#include <stdio.h>
#include <malloc.h>
#include <stdlib.h>
#include <crtdbg.h>
int main( void )
{
long *buffer;
size_t size;
// Call _malloc_dbg to include the filename and line number
// of our allocation request in the header
buffer = (long *)_malloc_dbg( 40 * sizeof(long),
_NORMAL_BLOCK, __FILE__, __LINE__ );
if( buffer == NULL )
exit( 1 );
// Get the size of the buffer by calling _msize_dbg
size = _msize_dbg( buffer, _NORMAL_BLOCK );
printf( "Size of block after _malloc_dbg of 40 longs: %u\n", size );
// Expand the buffer using _expand_dbg and show the new size
buffer = (long *)_expand_dbg( buffer, size + sizeof(long),
_NORMAL_BLOCK, __FILE__, __LINE__ );
if( buffer == NULL )
exit( 1 );
size = _msize_dbg( buffer, _NORMAL_BLOCK );
printf( "Size of block after _expand_dbg of 1 more long: %u\n",
size );
free( buffer );
exit( 0 );
}
주석
이 프로그램의 출력을 컴퓨터의 모든 섹션을 확장하는 능력에 따라 달라집니다. 모든 섹션이 확장 되어 있으면 출력은 출력 섹션에 반영됩니다.
해당 .NET Framework 항목
해당 사항 없음. 표준 C 함수를 호출하려면 PInvoke를 사용합니다. 자세한 내용은 플랫폼 호출 예제를 참조하십시오.