_recalloc
realloc 및 calloc의 조합입니다.배열에 메모리를 다시 할당 하 고 해당 요소 0으로 초기화 합니다.
void *_recalloc(
void *memblock
size_t num,
size_t size
);
매개 변수
memblock
이전에 할당 된 메모리 블록에 대 한 포인터입니다.num
요소의 수입니다.size
각 요소의 길이 (바이트)에서입니다.
반환 값
_recalloc반환 된 void 재할당 (및 가능한 경우 이동) 메모리 블록에 대 한 포인터입니다.
블록을 주어진된 크기 확장 합니다 메모리가 부족 하 여 없으면 원본 블록 왼쪽 변경 되지 않는 경우, 및 NULL 이 반환 됩니다.
요청 된 크기 0 인 경우에 블록이 가리키는 의해 memblock 해제 됩니다. 반환 값이 NULL, 및 memblock 에서 해제 된 블록을 가리키는 왼쪽입니다.
저장소가 저장소의 모든 종류의 개체에 대 한 적절 한 정렬 되어야 보장 됩니다 반환 값을 가리킵니다.이외의 다른 형식에는 포인터를 가져올 수 void, 반환 값을 캐스팅 하는 형식을 사용 합니다.
설명
_recalloc 함수가 할당 된 메모리 블록의 크기를 변경 합니다.memblock 인수가 가리키는 메모리 블록의 시작 부분에.경우 memblock 입니다 NULL, _recalloc 같은 방식으로 동작 하는 calloc 새 블록을 할당 하 고 num * size 바이트입니다.각 요소는 0으로 초기화 됩니다.경우 memblock 수 없습니다 NULL, 그 이전 호출에 의해 반환 되는 포인터 여야 합니다 calloc, malloc, 또는 realloc.
새 메모리 위치에 새 블록을 되므로 포인터 반환 _ 여recalloc 포인터가 전달 되지 않을 수도 있는 memblock 인수입니다.
_recalloc설정 하는 errno 에 ENOMEM 메모리 할당 오류가 발생 하는 경우 또는 메모리 양을 초과할 경우 _HEAP_MAXREQ.이 문제 및 기타 오류 코드에 대 한 자세한 내용은 errno, _doserrno, _sys_errlist, _sys_nerr.
recalloc호출 realloc C++를 사용 하 여 _set_new_mode 새 처리기 모드를 설정 하는 함수입니다.새 처리기 모드를 나타내는 것인지, 오류가 발생 하면 realloc 으로 설정 새 처리기 루틴을 호출 하는 것 _set_new_handler.기본적으로 realloc 메모리 할당에 실패 시 새 처리기 루틴을 호출 하지 않습니다.이 기본 동작을 재정의할 수 있습니다 있도록, _recalloc 메모리를 할당 하지 못할 realloc 에서 동일한 새 처리기 루틴을 호출 방법을 new 연산자 같은 이유로 실패 하는 경우를 하지.기본값을 재정의 하려면 호출
_set_new_mode(1)
초기 단계에서 프로그램 또는 NEWMODE.OBJ와 연결 합니다.
응용 프로그램 _ C 런타임 라이브러리의 디버그 버전에 연결 되어 때recalloc 확인 _recalloc_dbg.디버깅 프로세스 동안 힙 관리 하는 방법에 대 한 자세한 내용은 참조 하십시오. CRT 디버그 힙.
_recalloc표시 된 __declspec(noalias) 및 __declspec(restrict), 함수가 전역 변수를 수정 하려면 보장 되 고 별칭이 지정 된 포인터가 반환 수 없습니다.자세한 내용은 별칭 및 제한.
요구 사항
루틴 |
필수 헤더 |
---|---|
_recalloc |
<stdlib.h> 및 <malloc.h> |
추가 호환성 정보를 참조 하십시오. 호환성 소개에서 합니다.
해당 .NET Framework 항목
해당 사항 없음. 표준 C 함수를 호출할 수 있습니다 PInvoke. 자세한 내용은 플랫폼 호출 예제.