_aligned_offset_realloc_dbg
할당되었거나 _aligned_offset_malloc
(디버그 버전에만 해당) 할당된 _aligned_malloc
메모리 블록의 크기를 변경합니다.
구문
void * _aligned_offset_realloc_dbg(
void *memblock,
size_t size,
size_t alignment,
size_t offset,
const char *filename,
int linenumber
);
매개 변수
memblock
현재 메모리 블록 포인터입니다.
size
메모리 할당의 크기입니다.
alignment
맞춤 값으로 2의 정수 거듭제곱이어야 합니다.
offset
맞춤을 강제하는 메모리 할당으로의 오프셋입니다.
filename
작업을 요청한 aligned_offset_realloc
원본 파일의 이름 또는 NULL
.
linenumber
작업이 요청되었거나 NULL
소스 파일의 aligned_offset_realloc
줄 번호입니다.
반환 값
_aligned_offset_realloc_dbg
는 다시 할당된(그리고 이동되었을 수 있는) 메모리 블록에 대한 void 포인터를 반환합니다. 반환 값은 NULL
크기가 0이고 버퍼 인수가 아닌 NULL
경우 또는 블록을 지정된 크기로 확장할 수 있는 메모리가 충분하지 않은 경우입니다. 첫 번째 경우 원래 블록이 해제됩니다. 두 번째 경우 원래 블록은 변경되지 않습니다. 반환 값은 모든 유형의 개체의 스토리지에 적합하게 정렬된 스토리지 공간을 가리킵니다. void가 아닌 형식의 포인터를 얻으려면 반환 값에 형식 캐스팅을 사용합니다.
설명
_aligned_offset_realloc_dbg
는 함수의 디버그 버전입니다 _aligned_offset_realloc
. 정의되지 않은 경우 _DEBUG
각 호출 _aligned_offset_realloc_dbg
이 호출로 _aligned_offset_realloc
줄어듭니다. 둘 다 _aligned_offset_realloc
기본 힙에서 메모리 블록을 다시 할당하지만_aligned_offset_realloc_dbg
, 블록의 사용자 부분 양쪽에 있는 버퍼와 누출을 테스트하기 위한 정보, 할당 요청의 원본을 확인하는 정보 등 filename
/linenumber
여러 디버깅 기능을 수용합니다._aligned_offset_realloc_dbg
블록 형식 매개 변수를 사용하여 특정 할당 유형을 추적하는 것은 정렬된 할당에 대해 지원되는 디버그 기능이 아닙니다. 정렬된 할당은 블록 형식으로 _NORMAL_BLOCK
표시됩니다.
마찬가지로 _aligned_offset_malloc
구조 _aligned_offset_realloc_dbg
체 내의 오프셋에서 구조체를 정렬할 수 있습니다.
_realloc_dbg
는 요청된 newSize
보다 약간 더 많은 공간을 지정된 메모리 블록에 다시 할당합니다. newSize
는 원래 할당된 메모리 블록의 크기보다 더 크거나 작을 수 있습니다. 추가 공간은 디버그 힙 관리자가 디버그 메모리 블록을 연결하고 애플리케이션에 디버그 헤더 정보 및 덮어쓰기 버퍼를 제공하는 데 사용됩니다. 다시 할당은 원래 메모리 블록을 힙의 다른 위치로 이동하고 메모리 블록의 크기도 변경할 수 있습니다. 메모리 블록이 이동하면 원래 블록의 내용을 덮어씁니다.
이 함수는 메모리 할당에 실패한 경우 또는 요청된 크기가 errno
보다 큰 경우 ENOMEM
를 _HEAP_MAXREQ
으로 설정합니다. 에 대한 errno
자세한 내용은 , , _doserrno
_sys_errlist
및_sys_nerr
를 참조하세요errno
. 또한 _aligned_offset_realloc_dbg
는 매개 변수의 유효성을 검사합니다. 2의 힘이 아니거나 0이 아니고 0보다 크거나 같은 size
경우 offset
alignment
이 함수는 매개 변수 유효성 검사에 설명된 대로 잘못된 매개 변수 처리기를 호출합니다. 계속해서 실행하도록 허용한 경우 이 함수는 NULL
을 반환하고 errno
를 EINVAL
로 설정합니다.
기본 힙의 디버그 버전에서 메모리 블록을 할당, 초기화 및 관리하는 방법에 대한 자세한 내용은 CRT 디버그 힙 세부 정보를 참조 하세요. 할당 블록 형식 및 사용 방법에 대한 자세한 내용은 디버그 힙의 블록 유형을 참조 하세요. 표준 힙 함수와 해당 디버그 버전 간의 차이점에 대한 자세한 내용은 힙 할당 함수의 디버그 버전을 참조 하세요.
요구 사항
루틴에서 반환된 값 | 필수 헤더 |
---|---|
_aligned_offset_realloc_dbg |
<crtdbg.h> |
호환성에 대한 자세한 내용은 호환성을 참조하세요.
라이브러리
C 런타임 라이브러리의 디버그 버전만 해당됩니다.