Condividi tramite


_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 elementi

  • size
    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.

Vedere anche

Riferimenti

Allineamento dati

_recalloc

_aligned_recalloc