WSGetUnicodeString (C 函数)

int WSGetUnicodeString(WSLINK link,unsigned short **s,long *n)

从由 link 指定的 WSTP 连接中获取一个对应于一个字符字符串,把字符串以16位 Unicode 字符序列存在 s 中.

更多信息

  • WSGetUnicodeString() 为字符字符串分配内存. 必须调用 WSDisownUnicodeString() 释放该内存. 如果 WSGetUnicodeString() 失败并且函数的返回值表明一个错误,不要调用含有 s 内容的 WSDisownUnicodeString().
  • WSGetUnicodeString() 返回不可变数据.
  • WSGetUnicodeString() 把所有字符直接存为16位 UCS-2 形式.
  • ASCII 字符与一个零(null)高阶字节一起存储.
  • 若发生错误,则 WSGetUnicodeString() 返回0;若函数成功,则返回非零值.
  • 如果 WSGetUnicodeString() 失败,则使用 WSError() 检索错误代码.
  • WSGetUnicodeString() 等同于 WSGetUCS2String().

范例

基本范例  (1)

#include "wstp.h"

/* read a UCS-2 encoded string from a link */

void f(WSLINK lp)
{
    const unsigned short *string;
    long length;

    if(! WSGetUnicodeString(lp, &string, &length))
        {
            /* unable to read the UCS-2 string */
            return;
        }

    /* ... */

    WSDisownUnicodeString(lp, string, length);
}