Exportar (0) Imprimir
Expandir todo
and
div
eof
not
or
xor
Expandir Minimizar
Este artículo proviene de un motor de traducción automática. Mueva el puntero sobre las frases del artículo para ver el texto original. Más información.
Traducción
Original

_malloc_dbg

Asigna un bloque de memoria del montón con el espacio adicional para un encabezado de depuración y sobrescribe los búferes (versión de depuración solo).

void *_malloc_dbg(
   size_t size,
   int blockType,
   const char *filename,
   int linenumber 
);

size

Tamaño solicitado del bloque de memoria (en bytes).

blockType

Tipo de bloque de memoria solicitado: _CLIENT_BLOCK o _NORMAL_BLOCK.

filename

Puntero al nombre del archivo de código fuente que solicitó la operación de asignación o valor NULL.

linenumber

Número de línea del archivo de código fuente en la que se solicitó la operación de asignación o valor NULL.

Los parámetros filename y linenumber solo están disponibles cuando se ha llamado a _malloc_dbg explícitamente o se ha definido la constante de preprocesador _CRTDBG_MAP_ALLOC.

Cuando se complete correctamente, esta función devuelve un puntero a la parte del usuario del bloque de memoria asignado, llama a la nueva función de controlador, o devuelve NULL. Para obtener una descripción completa del comportamiento de retorno, vea la sección de comentarios más abajo. Para obtener más información sobre cómo se usa la nueva función de controlador, vea la función de malloc .

_malloc_dbg es una versión de depuración de la función de malloc . Si no se define _DEBUG, cada llamada a _malloc_dbg se reduce a una llamada a malloc. malloc y _malloc_dbg asignan un bloque de memoria del montón base, pero _malloc_dbg proporciona varias características de depuración: búferes situados a cada lado de la parte del usuario del bloque en el que se va a comprobar si hay pérdidas, un parámetro de tipo de bloque para realizar el seguimiento de tipos de asignación concretos, e información sobre filename o linenumber para determinar el origen de las solicitudes de asignación.

_malloc_dbg asigna el bloque de memoria con un poco más de espacio que el size solicitado. El administrador del montón de depuración usa el espacio adicional para vincular los bloques de memoria de depuración, y para proporcionar a la aplicación información de encabezado de depuración y sobrescribir los búferes. Cuando se asigna el bloque, la parte del usuario de bloque se rellena con el valor 0xCD y cada uno de los búferes sobrescritos se rellena con 0xFD.

_malloc_dbg establece errno en ENOMEM si se produce un error de asignación de memoria o si la cantidad de memoria necesaria (incluida la sobrecarga ya mencionada) es mayor que _HEAP_MAXREQ. Para obtener más información sobre este y otros códigos de error, vea errno, _doserrno, _sys_errlist y _sys_nerr.

Para obtener información sobre cómo los bloques de memoria se asignan, inicialice, y se administran en la versión de depuración del montón base, vea Administración de memoria y el montón de depuración.

Para obtener información sobre la asignación de tipos de bloque y cómo se usan, vea Tipos de bloques en el montón de depuración.

Rutina

Encabezado necesario

_malloc_dbg

<crtdbg.h>

Para obtener más información de compatibilidad, vea Compatibilidad en la Introducción.

Bibliotecas

Solo las versiones de depuración de las bibliotecas en tiempo de ejecución de C.

Para obtener un ejemplo de cómo usar _malloc_dbg, vea crt_dbg1.

No es aplicable Para llamar a la función estándar de C, use PInvoke. Para obtener más información, vea Ejemplos de invocación de plataforma.

Adiciones de comunidad

AGREGAR
Mostrar:
© 2014 Microsoft