MLGetByteArray()
This feature is not supported on the Wolfram Cloud.

WSGetByteArrayに置き換えられた.

int MLGetByteArray(MLINK link,unsigned char **a,int **dims,char ***heads,int *d)
で指定された MathLink 接続から1バイトサイズの整数配列を得て,配列を a,次元を dims,深さを d に保持しておく. 

詳細詳細

  • 配列 は,として宣言されたC配列のようにメモリにレイアウトされる.
  • heads は配列の各レベルにおいて頭部として現れる記号名に対応する文字列のリストを返す.
  • MLGetByteArray()が割り当てるメモリは,MLReleaseByteArray()を呼び出して解放しなければならない.MLGetByteArray()が不成功で関数の返す値がエラーを示している場合には,a の内容についてMLReleaseByteArray()を呼び出してはならない.
  • MLGetByteArray()は不変のデータを返す.
  • MLGetByteArray()はエラーがあると0を返し,関数が成功すると0以外の値を返す.
  • MLError()を使うと,MLGetByteArray()が不成功の場合にエラーコードを引き出すことができる.
  • MLGetByteArray()MathLink ヘッダファイルmathlink.hの中で宣言される.

例題例題すべて開くすべて閉じる

  (1)  (1)

#include "mathlink.h"

/* read a byte-sized integer array from a link */

void f(MLINK lp)
{
    unsigned char *data;
    int *dims;
    char **heads;
    int d;

    if(! MLGetByteArray(lp, &data, &dims, &heads, &d))
        {
            /* unable to read the integer array from lp */
            return;
        }

    /* ... */

    MLReleaseByteArray(lp, data, dims, heads, d);
}