次の方法で共有


Marshal.Copy メソッド (IntPtr, Char , Int32, Int32)

アンマネージ メモリ ポインタのデータを文字列のマネージ配列にコピーします。

Overloads Public Shared Sub Copy( _
   ByVal source As IntPtr, _   ByVal destination() As Char, _   ByVal startIndex As Integer, _   ByVal length As Integer _)
[C#]
public static void Copy(IntPtrsource,char[] destination,intstartIndex,intlength);
[C++]
public: static void Copy(IntPtrsource,__wchar_tdestination __gc[],intstartIndex,intlength);
[JScript]
public static function Copy(
   source : IntPtr,destination : Char[],startIndex : int,length : int);

パラメータ

  • source
    コピー元のメモリ ポインタ。
  • destination
    コピー先の配列。
  • startIndex
    Copy を開始する配列内の 0 から始まるインデックス。
  • length
    コピーする配列要素の数。

解説

C スタイルのアンマネージ配列には境界情報がありません。したがって、 startIndex パラメータと length パラメータを検証できません。したがって、 source パラメータに対応するアンマネージ データによって、その実効性にかかわらず、マネージ配列にデータが読み込まれます。 Marshal.Copy メソッドを呼び出す前に、適切なサイズでマネージ配列を初期化する必要があります。

メモ   このメソッドは SecurityAction.LinkDemand を使用して、信頼関係のないコードからの呼び出しを防ぎます。 SecurityPermissionAttribute.UnmanagedCode アクセス許可は、直前の呼び出し元にのみ要求されます。信頼性が一部しか確認されていないコードから呼び出すことができるコードの場合、ユーザー入力を検証せずに Marshal クラスに渡すことは避けてください。 LinkDemand メンバの使用に関する重要な制約事項については、「 Demand と LinkDemand 」を参照してください。

使用例

[Visual Basic, C#] アンマネージ メモリ ポインタのデータをマネージ配列にコピーする方法を次の例に示します。

 
Public Overloads Shared Sub Copy(source As IntPtr, _
  destination As Char(), startIndex As Integer, length As Integer)
      
[C#] 
public static void Copy(IntPtr source, char[] destination, 
  int startIndex, int length);
      

[C++, JScript] C++ および JScript のサンプルはありません。Visual Basic および C# のサンプルを表示するには、このページの左上隅にある言語のフィルタ ボタン 言語のフィルタ をクリックします。

必要条件

プラットフォーム: Windows 98, Windows NT 4.0, Windows Millennium Edition, Windows 2000, Windows XP Home Edition, Windows XP Professional, Windows Server 2003 ファミリ, .NET Compact Framework - Windows CE .NET

.NET Framework セキュリティ:

参照

Marshal クラス | Marshal メンバ | System.Runtime.InteropServices 名前空間 | Marshal.Copy オーバーロードの一覧 | Copy