Marshal.StringToCoTaskMemAnsi メソッド
アンマネージ COM タスク アロケータから割り当てられたメモリ ブロックに、マネージ String の内容をコピーします。
Public Shared Function StringToCoTaskMemAnsi( _
ByVal s As String _) As IntPtr
[C#]
public static IntPtr StringToCoTaskMemAnsi(strings);
[C++]
public: static IntPtr StringToCoTaskMemAnsi(String* s);
[JScript]
public static function StringToCoTaskMemAnsi(
s : String) : IntPtr;
パラメータ
- s
コピーされるマネージ文字列。
戻り値
文字列に割り当てられたメモリ ブロックへのポインタを表す整数。 null 参照 (Visual Basic では Nothing) 文字列が提供された場合は 0。
例外
例外の種類 | 条件 |
---|---|
OutOfMemoryException | 使用できるメモリが不足しています。 |
解説
StringToCoTaskMemAnsi は、カスタム マーシャリングを実行するとき、またはマネージ コードとアンマネージ コードを混在させるときに使用します。このメソッドは文字列で必要とされるアンマネージ メモリを割り当てるため、必ず FreeCoTaskMem を呼び出すことによってメモリを解放してください。このメソッドは、 Marshal.PtrToStringAnsi と反対の機能を提供します。文字列の文字は、ANSI 文字としてコピーされます。
メモ このメソッドは SecurityAction.LinkDemand を使用して、信頼関係のないコードからの呼び出しを防ぎます。 SecurityPermissionAttribute.UnmanagedCode アクセス許可は、直前の呼び出し元にのみ要求されます。信頼性が一部しか確認されていないコードから呼び出すことができるコードの場合、ユーザー入力を検証せずに Marshal クラスに渡すことは避けてください。 LinkDemand メンバの使用に関する重要な制約事項については、「 Demand と LinkDemand 」を参照してください。
必要条件
プラットフォーム: Windows 98, Windows NT 4.0, Windows Millennium Edition, Windows 2000, Windows XP Home Edition, Windows XP Professional, Windows Server 2003 ファミリ
.NET Framework セキュリティ:
- SecurityPermission (アンマネージ コードを操作するために必要なアクセス許可) SecurityPermissionFlag.UnmanagedCode (関連する列挙体)
参照
Marshal クラス | Marshal メンバ | System.Runtime.InteropServices 名前空間 | FreeCoTaskMem | PtrToStringAnsi