MLAllocator (C 関数)

MLAllocatorWSAllocatorに置き換えられた.

MathLink形式の一つで,unsigned longを引数として取り,void *を返還形式として持つ関数に, 関数ポインタを説明する.

詳細

  • メモリアロケータ(割当て)関数は,同じ位置に現れる要素をまとめることができるものでなくてはならない.
  • 64ビットのWindowsプラットフォーム上では, アロケータは unsigned __mlint64を引数として取る.
  • MLAllocator()は,MathLinkヘッダファイル mathlink.hの中で宣言される.

例題

  (1)

#include <stdlib.h>
#include "mathlink.h"

/* AppAllocator implements a custom memory allocator */
void * AppAllocator(unsigned long size)
{
    return malloc(size);
}


/* AppDeallocator implements a custom memory deallocator */
void AppDeallocator(void *m)
{
    free(m);
}


int main(int argc, char **argv)
{
    MLENV env;
    MLINK link;
    MLParameters p;
    int error;

    MLSetAllocParameter((char *)p, AppAllocator, AppDeallocator);

    env = MLInitialize((char *)p);
    if(env == (MLENV)0)
        { /* unable to initialize the MathLink environment */ }

    link = MLOpenArgcArgv(env, argc, argv, &error);
    if(link == (MLINK)0)
        { /* unable to create the link */ }

    /* ... */

    MLClose(link);
    MLDeinitialize(env);

    return 0;
}