다음을 통해 공유


_aligned_offset_recalloc

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

구문

void * _aligned_offset_recalloc(
   void *memblock,
   size_t num,
   size_t size,
   size_t alignment,
   size_t offset
);

매개 변수

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

number
요소의 수입니다.

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

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

offset
맞춤을 강제하는 메모리 할당으로의 오프셋입니다.

반환 값

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

_aligned_offset_recalloc 가 표시 __declspec(noalias) 되고 __declspec(restrict), 이는 함수가 전역 변수를 수정하지 않도록 보장되고 반환된 포인터가 별칭이 지정되지 않음을 의미합니다. 자세한 내용은 noaliasrestrict를 참조하세요.

설명

마찬가지로 _aligned_offset_malloc구조 _aligned_offset_recalloc 체 내의 오프셋에서 구조체를 정렬할 수 있습니다.

_aligned_offset_recallocmalloc를 기반으로 합니다. 사용에 _aligned_offset_malloc대한 자세한 내용은 다음을 참조하세요 malloc. memblockNULL인 경우 함수는 내부적으로 _aligned_offset_malloc를 호출합니다.

메모리 할당에 실패한 경우 또는 요청된 크기(number * size)가 _HEAP_MAXREQ보다 큰 경우 이 함수는 errnoENOMEM으로 설정합니다. 에 대한 errno자세한 내용은 , , _doserrno_sys_errlist_sys_nerr 를 참조하세요errno. 또한 _aligned_offset_recalloc는 매개 변수의 유효성을 검사합니다. 2의 힘이 아니거나 0이 아니고 요청된 것보다 크거나 같은 경우 alignment offset 이 함수는 매개 변수 유효성 검사에 설명된 대로 잘못된 매개 변수 처리기를 호출합니다.size 계속해서 실행하도록 허용한 경우 이 함수는 NULL을 반환하고 errnoEINVAL로 설정합니다.

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

요구 사항

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

참고 항목

데이터 맞춤
_recalloc
_aligned_recalloc