mxMalloc (C и Фортран)

Выделите неинициализированное использование динамической памяти диспетчер памяти MATLAB

Синтаксис C

#include "matrix.h"
#include <stdlib.h>
void *mxMalloc(mwSize n);

Синтаксис языка ФОРТРАН

#include "fintrf.h"
mwPointer mxMalloc(n)
mwSize n

Аргументы

n

Количество байтов, чтобы выделить для n, больше, чем 0

Возвращается

Указатель на запуск выделенной динамической памяти, в случае успеха. Если неудачный в MAT или автономном приложении механизма, то mxMalloc возвращает NULL в C (0 на Фортране). Если неудачный в файле MEX, то файл MEX отключает и управление возвращается к подсказке MATLAB®.

mxMalloc неудачен, когда существует недостаточное свободное пространство "кучи".

Если вы вызываете mxMalloc в C со значением n = 0, то MATLAB возвращает или NULL или допустимый указатель.

Описание

mxMalloc выделяет непрерывное пространство "кучи", достаточное, чтобы содержать байты n. Чтобы выделить память в приложениях MATLAB, используйте mxMalloc вместо функции ANSI® C malloc.

В файлах MEX, но не MAT или приложениях механизма, mxMalloc указывает выделенную память с диспетчером памяти MATLAB. Когда управление возвращается к посдказке MATLAB, диспетчер памяти затем автоматически освобождает или освобождает, эта память.

Как вы справляетесь, память, созданная этой функцией, зависит от цели данных, присвоенных ему. Если вы присваиваете его выходному аргументу в plhs[] с помощью функции mxSetPr, то MATLAB ответственен за освобождение памяти.

При использовании данные внутренне, то диспетчер памяти MATLAB ведет список всей памяти, выделенной функцией, и автоматически освобождает (освобождает) память, когда управление возвращается к посдказке MATLAB. В целом мы рекомендуем, чтобы функции файла MEX уничтожили свои собственные временные массивы и освободили их собственную динамически выделенную память. Более эффективно выполнить эту очистку в исходном файле MEX, чем полагаться на автоматический механизм. Поэтому, когда вы заканчиваете использовать память, выделенную этой функцией, вызовите mxFree, чтобы освободить память.

Если вы не присваиваете это данные выходному аргументу, и вы хотите, чтобы он сохранился после того, как файл MEX завершается, то вызовите mexMakeMemoryPersistent после вызывания этой функции. Если вы пишете файл MEX с постоянной памятью, то, несомненно, зарегистрируете функцию mexAtExit к свободной выделенной памяти в конечном счете, ваш файл MEX очищен.

Примеры

См. следующие примеры в matlabroot / extern / examples / mx.

См. следующие примеры в matlabroot / extern / examples / refbook.

Представлено до R2006a

Была ли эта тема полезной?