_aligned_offset_recalloc
Modifica la dimensione di un blocco di memoria che è stato allocato con _aligned_malloc o _aligned_offset_malloc e inizializza la memoria a 0.
void * _aligned_offset_recalloc(
void *memblock,
size_t num,
size_t size,
size_t alignment,
size_t offset
);
Parametri
memblock
Il puntatore al blocco di memoria corrente.num
Numero di elementisize
Lunghezza in byte di ogni elemento.alignment
Il valore di allineamento, che deve essere una potenza intera di 2.offset
L'offset dell'allocazione di memoria per forzare l'allineamento.
Valore restituito
_aligned_offset_recalloc restituisce un puntatore void al blocco di memoria riallocato (ed eventualmente spostato). Il valore restituito è NULL se la dimensione è zero e l'argomento del buffer non è NULL, o se non è disponibile memoria sufficiente per espandere il blocco alla dimensione specificata. Nel primo caso, il blocco originale viene liberato. Nel secondo caso, il blocco originale rimane invariato. I valore restituito punta ad uno spazio di memoria che garantisce l'allineamento adeguato per l'archiviazione di qualsiasi tipo di oggetto. Per ottenere un puntatore a un tipo diverso da void, utilizzare un cast di tipo sul valore di ritorno.
_aligned_offset_recalloc è contrassegnata in __declspec(noalias) e __declspec(restrict), pertanto la funzione garantisce che le variabili globali non vengono modificate, e che il puntatore restituito è già utilizzato. Per ulteriori informazioni, vedere noalias e limiti.
Note
Come _aligned_offset_malloc, _aligned_offset_recalloc consente a una struttura di essere allineata su true in un offset nella struttura.
_aligned_offset_recalloc è basato su malloc. Per ulteriori informazioni sull'utilizzo di _aligned_offset_malloc, consultare malloc. Se memblock è NULL, la funzione chiama _aligned_offset_malloc internamente.
Questa funzione imposta errno a ENOMEM se non è riuscita l'allocazione della memoria o se la dimensione richiesta (num * size) è maggiore di _HEAP_MAXREQ. Per ulteriori informazioni su errno, vedere errno, _doserrno, _sys_errlist, and _sys_nerr. Inoltre, _aligned_offset_recalloc convalida i suoi parametri. Se alignment non è una potenza di 2 o se offset è maggiore o uguale alla dimensione richiesta e diversa da zero, questa funzione invoca il gestore del parametro non valido, come descritto in Convalida dei parametri. Se l'esecuzione può continuare, questa funzione restituisce NULL e imposta errno su EINVAL.
Requisiti
Routine |
Intestazione obbligatoria |
---|---|
_aligned_offset_recalloc |
<malloc.h> |
Equivalente .NET Framework
Non applicabile. Per chiamare la funzione standard C, utilizzare PInvoke. Per ulteriori informazioni, vedere Esempi di Invocazione della Piattaforma.