外部インタフェース/API リファレンス | ![]() ![]() |
MATLABのメモリマネージャを使ってダイナミックメモリを割り当てます。
C 言語表示
#include "matrix.h" #include <stdlib.h> void *mxMalloc(size_t n);
戻り値
成功した場合は、割り当てられたダイナミックメモリの先頭のポインタ。スタンドアロン(非MEX-ファイル)アプリケーションで成功しない場合、mxMalloc
はNULL
を出力します。MEX-ファイルで成功しない場合、MEX-ファイルは終了し、制御はMATLABプロンプトに戻ります。
mxMalloc
は十分なフリーのヒープ領域がない場合は成功しません。
詳細
MATLABアプリケーションは、常にmalloc
ではなくmxMalloc
を呼び出してメモリを割り当てます。mxMalloc
は、スタンドアロンMATLABアプリケーションとMEX-ファイルとでは異なる動作をすることに注意してください。
MEX-ファイルでは、mxMalloc
はつぎのことを自動的に行います。
n
バイトを保持するための連続するヒープ領域を割り当てます。MATLABのメモリ管理機能は、mxMalloc
によって割り当てられたすべてのメモリのリストをもっています。MATLABメモリ管理機能は、制御がMATLABプロンプトに戻ったときにすべてのMEX-ファイルを自動的に開放(デアロケート)します。
スタンドアロンMATLABアプリケーションでは、mxMalloc
はデフォルトでANSI C関数malloc
を呼び出します。このデフォルトの動作が好ましくない場合は、ユーザ自身がメモリ割り当てルーチンを書き、mxSetAllocFcns
を使ってそのルーチンを登録することができます。その後、mxMalloc
が呼び出されるときには、mxMalloc
はmalloc
の代わりにユーザ定義のメモリ割り当てルーチンを呼び出します。
デフォルトでは、MEX-ファイルでは、mxMalloc
は固定でないmxMalloc
データを生成します。言い換えると、メモリ管理機能は、MEX-ファイルが終了すると直ちにメモリを自動的に開放します。MEX-ファイルが終了した後でメモリを固定にしたい場合は、mxMalloc
を呼び出した後でmexMakeMemoryPersistent
を呼び出してください。固定メモリを使ってMEX-ファイルを書く場合は、MEX-ファイルがクリアされたイベントで割り当てられたメモリを開放する関数mexAtExit
を登録してください。
mxMalloc
によって割り当てられたメモリの利用を終了するときには、mxFree
を呼び出してください。mxFree
はメモリを開放します。
例題
examples
ディレクトリのmx
サブディレクトリのmxmalloc.c
を参照してください。さらに、examples
ディレクトリのmx
サブディレクトリのmxsetdimensions.c
を参照してください。
参考
mxCalloc
, mxFree
, mxDestroyArray
, mexMakeArrayPersistent
,mexMakeMemoryPersistent
, mxSetAllocFcns
![]() | mxIsUint32 | mxRealloc | ![]() |