Marshal.WriteIntPtr Metode
Definisi
Penting
Beberapa informasi terkait produk prarilis yang dapat diubah secara signifikan sebelum dirilis. Microsoft tidak memberikan jaminan, tersirat maupun tersurat, sehubungan dengan informasi yang diberikan di sini.
Menulis nilai bilangan bulat berukuran asli prosesor ke memori yang tidak dikelola. Bilangan bulat 32-bit ditulis pada sistem 32-bit, dan bilangan bulat 64-bit ditulis pada sistem 64-bit. Menulis ke lokasi memori yang tidak ditandatangani didukung.
Overload
WriteIntPtr(IntPtr, IntPtr) |
Menulis nilai bilangan bulat berukuran asli prosesor ke dalam memori yang tidak dikelola. |
WriteIntPtr(IntPtr, Int32, IntPtr) |
Menulis nilai bilangan bulat berukuran asli prosesor ke memori yang tidak dikelola pada offset tertentu. |
WriteIntPtr(Object, Int32, IntPtr) |
Kedaluwarsa.
Menulis nilai bilangan bulat berukuran asli prosesor ke memori yang tidak dikelola. |
WriteIntPtr(IntPtr, IntPtr)
- Sumber:
- Marshal.cs
- Sumber:
- Marshal.cs
- Sumber:
- Marshal.cs
Menulis nilai bilangan bulat berukuran asli prosesor ke dalam memori yang tidak dikelola.
public:
static void WriteIntPtr(IntPtr ptr, IntPtr val);
[System.Security.SecurityCritical]
public static void WriteIntPtr (IntPtr ptr, IntPtr val);
public static void WriteIntPtr (IntPtr ptr, IntPtr val);
[<System.Security.SecurityCritical>]
static member WriteIntPtr : nativeint * nativeint -> unit
static member WriteIntPtr : nativeint * nativeint -> unit
Public Shared Sub WriteIntPtr (ptr As IntPtr, val As IntPtr)
Parameter
- ptr
-
IntPtr
nativeint
Alamat dalam memori yang tidak dikelola untuk ditulis.
- val
-
IntPtr
nativeint
Nilai yang akan ditulis.
- Atribut
Pengecualian
ptr
bukan format yang dikenali.
-atau-
ptr
adalah null
.
-atau-
ptr
tidak valid.
Contoh
Contoh berikut menunjukkan cara membaca dan menulis ke array yang tidak dikelola menggunakan ReadIntPtr metode dan WriteIntPtr .
static void ReadWriteIntPtr()
{
// Allocate unmanaged memory.
int elementSize = Marshal.SizeOf(typeof(IntPtr));
IntPtr unmanagedArray = Marshal.AllocHGlobal(10 * elementSize);
// Set the 10 elements of the C-style unmanagedArray
for (int i = 0; i < 10; i++)
{
Marshal.WriteIntPtr(unmanagedArray, i * elementSize, ((IntPtr)(i + 1)));
}
Console.WriteLine("Unmanaged memory written.");
Console.WriteLine("Reading unmanaged memory:");
// Print the 10 elements of the C-style unmanagedArray
for (int i = 0; i < 10; i++)
{
Console.WriteLine(Marshal.ReadIntPtr(unmanagedArray, i * elementSize));
}
Marshal.FreeHGlobal(unmanagedArray);
Console.WriteLine("Done. Press Enter to continue.");
Console.ReadLine();
}
Sub ReadWriteIntPtr()
' Allocate unmanaged memory.
Dim elementSize As Integer = Marshal.SizeOf(GetType(IntPtr))
Dim unmanagedArray As IntPtr = Marshal.AllocHGlobal(10 * elementSize)
' Set the 10 elements of the C-style unmanagedArray
For i As Integer = 0 To 9
Marshal.WriteIntPtr(unmanagedArray, i * elementSize, CType(i + 1, IntPtr))
Next i
Console.WriteLine("Unmanaged memory written.")
Console.WriteLine("Reading unmanaged memory:")
' Print the 10 elements of the C-style unmanagedArray
For i As Integer = 0 To 9
Console.WriteLine(Marshal.ReadIntPtr(unmanagedArray, i * elementSize))
Next i
Marshal.FreeHGlobal(unmanagedArray)
Console.WriteLine("Done. Press Enter to continue.")
Console.ReadLine()
End Sub
Keterangan
WriteIntPtr memungkinkan interaksi langsung dengan array gaya IntPtr
C yang tidak dikelola, menghilangkan pengeluaran menyalin seluruh array yang tidak dikelola (menggunakan Marshal.Copy) ke array terkelola terpisah sebelum mengatur nilai elemennya.
Menulis ke lokasi memori yang tidak ditandatangani didukung.
Lihat juga
Berlaku untuk
WriteIntPtr(IntPtr, Int32, IntPtr)
- Sumber:
- Marshal.cs
- Sumber:
- Marshal.cs
- Sumber:
- Marshal.cs
Menulis nilai bilangan bulat berukuran asli prosesor ke memori yang tidak dikelola pada offset tertentu.
public:
static void WriteIntPtr(IntPtr ptr, int ofs, IntPtr val);
[System.Security.SecurityCritical]
public static void WriteIntPtr (IntPtr ptr, int ofs, IntPtr val);
public static void WriteIntPtr (IntPtr ptr, int ofs, IntPtr val);
[<System.Security.SecurityCritical>]
static member WriteIntPtr : nativeint * int * nativeint -> unit
static member WriteIntPtr : nativeint * int * nativeint -> unit
Public Shared Sub WriteIntPtr (ptr As IntPtr, ofs As Integer, val As IntPtr)
Parameter
- ptr
-
IntPtr
nativeint
Alamat dasar dalam memori tidak terkelola untuk ditulis.
- ofs
- Int32
Offset byte tambahan, yang ditambahkan ke ptr
parameter sebelum menulis.
- val
-
IntPtr
nativeint
Nilai yang akan ditulis.
- Atribut
Pengecualian
Alamat dasar (ptr
) ditambah byte offset (ofs
) menghasilkan alamat null atau tidak valid.
Contoh
Contoh berikut menunjukkan cara membaca dan menulis ke array yang tidak dikelola menggunakan ReadIntPtr metode dan WriteIntPtr .
static void ReadWriteIntPtr()
{
// Allocate unmanaged memory.
int elementSize = Marshal.SizeOf(typeof(IntPtr));
IntPtr unmanagedArray = Marshal.AllocHGlobal(10 * elementSize);
// Set the 10 elements of the C-style unmanagedArray
for (int i = 0; i < 10; i++)
{
Marshal.WriteIntPtr(unmanagedArray, i * elementSize, ((IntPtr)(i + 1)));
}
Console.WriteLine("Unmanaged memory written.");
Console.WriteLine("Reading unmanaged memory:");
// Print the 10 elements of the C-style unmanagedArray
for (int i = 0; i < 10; i++)
{
Console.WriteLine(Marshal.ReadIntPtr(unmanagedArray, i * elementSize));
}
Marshal.FreeHGlobal(unmanagedArray);
Console.WriteLine("Done. Press Enter to continue.");
Console.ReadLine();
}
Sub ReadWriteIntPtr()
' Allocate unmanaged memory.
Dim elementSize As Integer = Marshal.SizeOf(GetType(IntPtr))
Dim unmanagedArray As IntPtr = Marshal.AllocHGlobal(10 * elementSize)
' Set the 10 elements of the C-style unmanagedArray
For i As Integer = 0 To 9
Marshal.WriteIntPtr(unmanagedArray, i * elementSize, CType(i + 1, IntPtr))
Next i
Console.WriteLine("Unmanaged memory written.")
Console.WriteLine("Reading unmanaged memory:")
' Print the 10 elements of the C-style unmanagedArray
For i As Integer = 0 To 9
Console.WriteLine(Marshal.ReadIntPtr(unmanagedArray, i * elementSize))
Next i
Marshal.FreeHGlobal(unmanagedArray)
Console.WriteLine("Done. Press Enter to continue.")
Console.ReadLine()
End Sub
Keterangan
Metode ini menulis bilangan bulat 32 bit pada sistem 32 bit, dan bilangan bulat 64 bit pada sistem 64 bit.
WriteIntPtr memungkinkan interaksi langsung dengan array gaya IntPtr
C yang tidak dikelola, menghilangkan pengeluaran menyalin seluruh array yang tidak dikelola (menggunakan Marshal.Copy) ke array terkelola terpisah sebelum mengatur nilai elemennya.
Menulis ke lokasi memori yang tidak ditandatangani didukung.
Lihat juga
Berlaku untuk
WriteIntPtr(Object, Int32, IntPtr)
- Sumber:
- Marshal.cs
- Sumber:
- Marshal.cs
- Sumber:
- Marshal.cs
Perhatian
WriteIntPtr(Object, Int32, IntPtr) may be unavailable in future releases.
Menulis nilai bilangan bulat berukuran asli prosesor ke memori yang tidak dikelola.
public:
static void WriteIntPtr(System::Object ^ ptr, int ofs, IntPtr val);
[System.Obsolete("WriteIntPtr(Object, Int32, IntPtr) may be unavailable in future releases.")]
[System.Security.SecurityCritical]
public static void WriteIntPtr (object ptr, int ofs, IntPtr val);
[System.Obsolete("WriteIntPtr(Object, Int32, IntPtr) may be unavailable in future releases.")]
public static void WriteIntPtr (object ptr, int ofs, IntPtr val);
public static void WriteIntPtr (object ptr, int ofs, IntPtr val);
[System.Security.SecurityCritical]
public static void WriteIntPtr (object ptr, int ofs, IntPtr val);
[<System.Obsolete("WriteIntPtr(Object, Int32, IntPtr) may be unavailable in future releases.")>]
[<System.Security.SecurityCritical>]
static member WriteIntPtr : obj * int * nativeint -> unit
[<System.Obsolete("WriteIntPtr(Object, Int32, IntPtr) may be unavailable in future releases.")>]
static member WriteIntPtr : obj * int * nativeint -> unit
static member WriteIntPtr : obj * int * nativeint -> unit
[<System.Security.SecurityCritical>]
static member WriteIntPtr : obj * int * nativeint -> unit
Public Shared Sub WriteIntPtr (ptr As Object, ofs As Integer, val As IntPtr)
Parameter
- ptr
- Object
Alamat dasar dalam memori objek target yang tidak dikelola.
- ofs
- Int32
Offset byte tambahan, yang ditambahkan ke ptr
parameter sebelum menulis.
- val
-
IntPtr
nativeint
Nilai yang akan ditulis.
- Atribut
Pengecualian
Alamat dasar (ptr
) ditambah byte offset (ofs
) menghasilkan alamat null atau tidak valid.
ptr
ArrayWithOffset adalah objek . Metode ini tidak menerima ArrayWithOffset parameter.
Keterangan
WriteIntPtr memungkinkan interaksi langsung dengan array byte gaya C yang tidak dikelola, menghilangkan pengeluaran menyalin seluruh array yang tidak dikelola (menggunakan Marshal.Copy) ke array terkelola terpisah sebelum mengatur nilai elemennya.
Menulis ke lokasi memori yang tidak ditandatangani didukung.