다음을 통해 공유


_aligned_recalloc

할당 _aligned_malloc 된 메모리 블록의 크기를 변경하거나 _aligned_offset_malloc 메모리를 0으로 초기화합니다.

구문

void * _aligned_recalloc(
   void *memblock,
   size_t num,
   size_t size,
   size_t alignment
);

매개 변수

memblock
현재 메모리 블록 포인터입니다.

number
요소의 수입니다.

size
각 요소의 크기입니다(바이트).

alignment
맞춤 값으로 2의 정수 거듭제곱이어야 합니다.

반환 값

_aligned_recalloc는 다시 할당된(그리고 이동되었을 수 있는) 메모리 블록에 대한 void 포인터를 반환합니다. 반환 값은 NULL 크기가 0이고 버퍼 인수가 아닌 NULL경우 또는 블록을 지정된 크기로 확장할 수 있는 메모리가 충분하지 않은 경우입니다. 첫 번째 경우 원래 블록이 해제됩니다. 두 번째 경우 원래 블록은 변경되지 않습니다. 반환 값은 모든 유형의 개체의 스토리지에 적합하게 정렬된 스토리지 공간을 가리킵니다. void가 아닌 형식의 포인터를 얻으려면 반환 값에 형식 캐스팅을 사용합니다.

메모리를 다시 할당하고 블록의 맞춤을 변경하는 것은 오류입니다.

설명

_aligned_recallocmalloc를 기반으로 합니다. 사용에 _aligned_offset_malloc대한 자세한 내용은 다음을 참조하세요 malloc.

이 함수는 메모리 할당에 실패한 경우 또는 요청된 크기가 errno보다 큰 경우 ENOMEM_HEAP_MAXREQ으로 설정합니다. 에 대한 errno자세한 내용은 , , _doserrno_sys_errlist_sys_nerr 를 참조하세요errno. 또한 _aligned_recalloc는 매개 변수의 유효성을 검사합니다. 2의 전원이 아닌 경우 alignment 이 함수는 매개 변수 유효성 검사에 설명된 대로 잘못된 매개 변수 처리기를 호출합니다. 계속해서 실행하도록 허용한 경우 이 함수는 NULL을 반환하고 errnoEINVAL로 설정합니다.

기본적으로 이 함수의 전역 상태는 애플리케이션으로 범위가 지정됩니다. 이 동작을 변경하려면 CRT 전역 상태를 참조하세요.

요구 사항

루틴에서 반환된 값 필수 헤더
_aligned_recalloc <malloc.h>

참고 항목

데이터 맞춤
_recalloc
_aligned_offset_recalloc