MLGetUTF8Symbol (C 函数)

MLGetUTF8Symbol 已经被 WSGetUTF8Symbol 所取代.

int MLGetUTF8Symbol(MLINK link,const unsigned char **s,int *b,int *c)

从由 link 指定的 MathLink 连接中获取一个对应于一个符号名称的 UTF-8 编码字符字符串,把结果存在 s,字符串的字节数存在 b,字符串的字符数存在 c.

更多信息

  • MLGetUTF8Symbol() 为字符字符串分配内存. 必须调用 MLReleaseUTF8Symbol() 释放该内存. 如果 MLGetUTF8Symbol() 失败并且函数的返回值表明一个错误,不要调用含有 s 中的值的 MLReleaseUTF8Symbol().
  • MLGetUTF8Symbol() 返回不可变数据.
  • MLGetUTF8Symbol() 把所有字符直接存为 UTF-8 Unicode 编码形式.
  • MLGetUTF8Symbol() 在错误事件中返回0,如果函数成功则返回非零值.
  • 如果 MLGetUTF8Symbol() 失败,则使用 MLError() 检索错误代码.
  • MLGetUTF8Symbol() 在 MathLink 标头文件 mathlink.h 中被声明.

范例

基本范例  (1)

#include "mathlink.h"

/* read an UTF-8 encoded symbol from a link */

void f(MLINK lp)
{
    const unsigned char *symbol;
    int bytes;
    int characters;

    if(! MLGetUTF8Symbol(lp, &symbol, &bytes, &characters))
        {
            /* unable to read the UTF-8 symbol from lp */
            return;
        }

    /* ... */

    MLReleaseUTF8Symbol(lp, symbol, bytes);
}