Marshal.StringToCoTaskMemUni(String) メソッド

定義

アンマネージド COM タスク アロケーターから割り当てられたメモリ ブロックに、マネージド String の内容をコピーします。

public:
 static IntPtr StringToCoTaskMemUni(System::String ^ s);
[System.Security.SecurityCritical]
public static IntPtr StringToCoTaskMemUni (string s);
public static IntPtr StringToCoTaskMemUni (string? s);
public static IntPtr StringToCoTaskMemUni (string s);
[<System.Security.SecurityCritical>]
static member StringToCoTaskMemUni : string -> nativeint
static member StringToCoTaskMemUni : string -> nativeint
Public Shared Function StringToCoTaskMemUni (s As String) As IntPtr

パラメーター

s
String

コピーされるマネージド文字列。

戻り値

IntPtr

nativeint

文字列に割り当てられたメモリ ブロックへのポインターを表す整数。s が null の場合は 0。

属性

例外

s パラメーターがオペレーティング システムで許可されている最大長を超えています。

使用できるメモリが不足しています。

注釈

StringToCoTaskMemUni は、カスタム マーシャリングや、マネージド コードとアンマネージド コードを混在する場合に使用する場合に便利です。 このメソッドは文字列に必要なアンマネージ メモリを割り当てるので、 を呼び出 Marshal.FreeCoTaskMemして常にメモリを解放します。 このメソッドは、 の逆の機能を Marshal.PtrToStringUni提供します。 文字列の文字は Unicode 文字としてコピーされます。

この API には、UTF-16 2 バイト エンコードである Unicode の Windows 定義が反映されています。 多くの Windows 以外のプラットフォームでは、 wchar_t データ型は 2 バイトではなく 4 バイトです。 コンパイラに問い合わせて、使用できるかどうかを確認するかchar16_t、代わりに使用する必要があるかどうかを確認wchar_tします。

適用対象

こちらもご覧ください