Marshal.StringToCoTaskMemUni(String) メソッド
定義
重要
一部の情報は、リリース前に大きく変更される可能性があるプレリリースされた製品に関するものです。 Microsoft は、ここに記載されている情報について、明示または黙示を問わず、一切保証しません。
アンマネージド 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
コピーされるマネージド文字列。
戻り値
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
します。
適用対象
こちらもご覧ください
.NET