Marshal.WriteInt64 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 bertanda tangan 64-bit ke memori yang tidak dikelola. Menulis ke lokasi memori yang tidak ditandatangani didukung.
Overload
WriteInt64(Object, Int32, Int64) |
Kedaluwarsa.
Menulis nilai bilangan bulat bertanda 64-bit ke memori yang tidak dikelola pada offset tertentu. |
WriteInt64(IntPtr, Int64) |
Menulis nilai bilangan bulat bertanda tangan 64-bit ke memori yang tidak dikelola. |
WriteInt64(IntPtr, Int32, Int64) |
Menulis nilai bilangan bulat bertanda 64-bit ke memori yang tidak dikelola pada offset tertentu. |
WriteInt64(Object, Int32, Int64)
- Sumber:
- Marshal.CoreCLR.cs
- Sumber:
- Marshal.CoreCLR.cs
- Sumber:
- Marshal.CoreCLR.cs
Perhatian
WriteInt64(Object, Int32, Int64) may be unavailable in future releases.
Menulis nilai bilangan bulat bertanda 64-bit ke memori yang tidak dikelola pada offset tertentu.
public:
static void WriteInt64(System::Object ^ ptr, int ofs, long val);
[System.Obsolete("WriteInt64(Object, Int32, Int64) may be unavailable in future releases.")]
[System.Security.SecurityCritical]
public static void WriteInt64 (object ptr, int ofs, long val);
[System.Obsolete("WriteInt64(Object, Int32, Int64) may be unavailable in future releases.")]
public static void WriteInt64 (object ptr, int ofs, long val);
public static void WriteInt64 (object ptr, int ofs, long val);
[System.Security.SecurityCritical]
public static void WriteInt64 (object ptr, int ofs, long val);
[<System.Obsolete("WriteInt64(Object, Int32, Int64) may be unavailable in future releases.")>]
[<System.Security.SecurityCritical>]
static member WriteInt64 : obj * int * int64 -> unit
[<System.Obsolete("WriteInt64(Object, Int32, Int64) may be unavailable in future releases.")>]
static member WriteInt64 : obj * int * int64 -> unit
static member WriteInt64 : obj * int * int64 -> unit
[<System.Security.SecurityCritical>]
static member WriteInt64 : obj * int * int64 -> unit
Public Shared Sub WriteInt64 (ptr As Object, ofs As Integer, val As Long)
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
- Int64
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
WriteInt64 memungkinkan interaksi langsung dengan array yang ditandatangani 64-bit 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
WriteInt64(IntPtr, Int64)
- Sumber:
- Marshal.cs
- Sumber:
- Marshal.cs
- Sumber:
- Marshal.cs
Menulis nilai bilangan bulat bertanda tangan 64-bit ke memori yang tidak dikelola.
public:
static void WriteInt64(IntPtr ptr, long val);
[System.Security.SecurityCritical]
public static void WriteInt64 (IntPtr ptr, long val);
public static void WriteInt64 (IntPtr ptr, long val);
[<System.Security.SecurityCritical>]
static member WriteInt64 : nativeint * int64 -> unit
static member WriteInt64 : nativeint * int64 -> unit
Public Shared Sub WriteInt64 (ptr As IntPtr, val As Long)
Parameter
- ptr
-
IntPtr
nativeint
Alamat dalam memori yang tidak dikelola untuk ditulis.
- val
- Int64
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 ReadInt64 metode dan WriteInt64 .
static void ReadWriteInt64()
{
// Allocate unmanaged memory.
int elementSize = 8;
IntPtr unmanagedArray = Marshal.AllocHGlobal(10 * elementSize);
// Set the 10 elements of the C-style unmanagedArray
for (int i = 0; i < 10; i++)
{
Marshal.WriteInt64(unmanagedArray, i * elementSize, ((Int64)(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.ReadInt64(unmanagedArray, i * elementSize));
}
Marshal.FreeHGlobal(unmanagedArray);
Console.WriteLine("Done. Press Enter to continue.");
Console.ReadLine();
}
Sub ReadWriteInt64()
' Allocate unmanaged memory.
Dim elementSize As Integer = 8
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.WriteInt64(unmanagedArray, i * elementSize, CType(i + 1, Int64))
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.ReadInt64(unmanagedArray, i * elementSize))
Next i
Marshal.FreeHGlobal(unmanagedArray)
Console.WriteLine("Done. Press Enter to continue.")
Console.ReadLine()
End Sub
Keterangan
WriteInt64 memungkinkan interaksi langsung dengan array yang ditandatangani 64-bit 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
WriteInt64(IntPtr, Int32, Int64)
- Sumber:
- Marshal.cs
- Sumber:
- Marshal.cs
- Sumber:
- Marshal.cs
Menulis nilai bilangan bulat bertanda 64-bit ke memori yang tidak dikelola pada offset tertentu.
public:
static void WriteInt64(IntPtr ptr, int ofs, long val);
[System.Security.SecurityCritical]
public static void WriteInt64 (IntPtr ptr, int ofs, long val);
public static void WriteInt64 (IntPtr ptr, int ofs, long val);
[<System.Security.SecurityCritical>]
static member WriteInt64 : nativeint * int * int64 -> unit
static member WriteInt64 : nativeint * int * int64 -> unit
Public Shared Sub WriteInt64 (ptr As IntPtr, ofs As Integer, val As Long)
Parameter
- ptr
-
IntPtr
nativeint
Alamat dasar dalam memori yang tidak dikelola untuk ditulis.
- ofs
- Int32
Offset byte tambahan, yang ditambahkan ke ptr
parameter sebelum menulis.
- val
- Int64
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 ReadInt64 metode dan WriteInt64 .
static void ReadWriteInt64()
{
// Allocate unmanaged memory.
int elementSize = 8;
IntPtr unmanagedArray = Marshal.AllocHGlobal(10 * elementSize);
// Set the 10 elements of the C-style unmanagedArray
for (int i = 0; i < 10; i++)
{
Marshal.WriteInt64(unmanagedArray, i * elementSize, ((Int64)(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.ReadInt64(unmanagedArray, i * elementSize));
}
Marshal.FreeHGlobal(unmanagedArray);
Console.WriteLine("Done. Press Enter to continue.");
Console.ReadLine();
}
Sub ReadWriteInt64()
' Allocate unmanaged memory.
Dim elementSize As Integer = 8
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.WriteInt64(unmanagedArray, i * elementSize, CType(i + 1, Int64))
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.ReadInt64(unmanagedArray, i * elementSize))
Next i
Marshal.FreeHGlobal(unmanagedArray)
Console.WriteLine("Done. Press Enter to continue.")
Console.ReadLine()
End Sub
Keterangan
WriteInt64 memungkinkan interaksi langsung dengan array yang ditandatangani 64-bit 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.