Marshal.ReadInt64 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.
Membaca bilangan bulat bertanda 64-bit dari memori yang tidak dikelola. Membaca dari lokasi memori yang tidak sejajar didukung.
Overload
ReadInt64(IntPtr) |
Membaca bilangan bulat bertanda 64-bit dari memori yang tidak dikelola. |
ReadInt64(IntPtr, Int32) |
Membaca bilangan bulat bertanda 64-bit pada offset tertentu dari memori yang tidak dikelola. |
ReadInt64(Object, Int32) |
Kedaluwarsa.
Membaca bilangan bulat bertanda 64-bit pada offset tertentu dari memori yang tidak dikelola. |
ReadInt64(IntPtr)
- Sumber:
- Marshal.cs
- Sumber:
- Marshal.cs
- Sumber:
- Marshal.cs
Membaca bilangan bulat bertanda 64-bit dari memori yang tidak dikelola.
public:
static long ReadInt64(IntPtr ptr);
[System.Security.SecurityCritical]
public static long ReadInt64 (IntPtr ptr);
public static long ReadInt64 (IntPtr ptr);
[<System.Security.SecurityCritical>]
static member ReadInt64 : nativeint -> int64
static member ReadInt64 : nativeint -> int64
Public Shared Function ReadInt64 (ptr As IntPtr) As Long
Parameter
- ptr
-
IntPtr
nativeint
Alamat dalam memori yang tidak terkelola untuk dibaca.
Mengembalikan
Bilangan bulat bertanda tangan 64-bit dibaca dari memori yang tidak dikelola.
- 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
Contoh berikut menunjukkan cara menggunakan ReadInt64 metode untuk membaca nilai variabel yang tidak dikelola __int64
.
using namespace System;
using namespace System::Runtime::InteropServices;
void main()
{
// Create an unmanaged __int64.
__int64 myVal = 42;
// Read the value as a managed Int64.
Int64 ^ myManagedVal = Marshal::ReadInt64((IntPtr) &myVal);
// Display the value to the console.
Console::WriteLine(myManagedVal);
}
Keterangan
ReadInt64 memiliki offset tersirat 0. Metode ini memungkinkan interaksi langsung dengan array gaya Int64
C yang tidak dikelola, menghilangkan pengeluaran menyalin seluruh array yang tidak dikelola (menggunakan Marshal.Copy) ke array terkelola terpisah sebelum membaca nilai elemennya.
Membaca dari lokasi memori yang tidak sejajar didukung.
Lihat juga
Berlaku untuk
ReadInt64(IntPtr, Int32)
- Sumber:
- Marshal.cs
- Sumber:
- Marshal.cs
- Sumber:
- Marshal.cs
Membaca bilangan bulat bertanda 64-bit pada offset tertentu dari memori yang tidak dikelola.
public:
static long ReadInt64(IntPtr ptr, int ofs);
[System.Security.SecurityCritical]
public static long ReadInt64 (IntPtr ptr, int ofs);
public static long ReadInt64 (IntPtr ptr, int ofs);
[<System.Security.SecurityCritical>]
static member ReadInt64 : nativeint * int -> int64
static member ReadInt64 : nativeint * int -> int64
Public Shared Function ReadInt64 (ptr As IntPtr, ofs As Integer) As Long
Parameter
- ptr
-
IntPtr
nativeint
Alamat dasar dalam memori yang tidak dikelola untuk dibaca.
- ofs
- Int32
Offset byte tambahan, yang ditambahkan ke ptr
parameter sebelum membaca.
Mengembalikan
Bilangan bulat bertanda tangan 64-bit dibaca dari memori tidak terkelola pada offset yang diberikan.
- 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
Contoh berikut menunjukkan cara menggunakan ReadInt64 metode untuk membaca nilai variabel yang tidak dikelola __int64
.
using namespace System;
using namespace System::Runtime::InteropServices;
void main()
{
// Create an unmanaged __int64 pointer.
__int64 * myVal;
__int64 tmp = 42;
// Initialize it to another value.
myVal = &tmp;
// Read value as a managed Int64.
Int64 ^ myManagedVal = Marshal::ReadInt64((IntPtr) myVal, 0);
// Display the value to the console.
Console::WriteLine(myManagedVal);
}
Keterangan
ReadInt64 memungkinkan interaksi langsung dengan array yang ditandatangani 64-bit yang tidak terkelola, menghilangkan pengeluaran menyalin seluruh array yang tidak dikelola (menggunakan Marshal.Copy) ke array terkelola terpisah sebelum membaca nilai elemennya.
Membaca dari lokasi memori yang tidak sejajar didukung.
Lihat juga
Berlaku untuk
ReadInt64(Object, Int32)
- Sumber:
- Marshal.CoreCLR.cs
- Sumber:
- Marshal.CoreCLR.cs
- Sumber:
- Marshal.CoreCLR.cs
Perhatian
ReadInt64(Object, Int32) may be unavailable in future releases.
Membaca bilangan bulat bertanda 64-bit pada offset tertentu dari memori yang tidak dikelola.
public:
static long ReadInt64(System::Object ^ ptr, int ofs);
[System.Obsolete("ReadInt64(Object, Int32) may be unavailable in future releases.")]
[System.Security.SecurityCritical]
public static long ReadInt64 (object ptr, int ofs);
[System.Obsolete("ReadInt64(Object, Int32) may be unavailable in future releases.")]
public static long ReadInt64 (object ptr, int ofs);
public static long ReadInt64 (object ptr, int ofs);
[System.Security.SecurityCritical]
public static long ReadInt64 (object ptr, int ofs);
[<System.Obsolete("ReadInt64(Object, Int32) may be unavailable in future releases.")>]
[<System.Security.SecurityCritical>]
static member ReadInt64 : obj * int -> int64
[<System.Obsolete("ReadInt64(Object, Int32) may be unavailable in future releases.")>]
static member ReadInt64 : obj * int -> int64
static member ReadInt64 : obj * int -> int64
[<System.Security.SecurityCritical>]
static member ReadInt64 : obj * int -> int64
Public Shared Function ReadInt64 (ptr As Object, ofs As Integer) As Long
Parameter
- ptr
- Object
Alamat dasar dalam memori objek sumber yang tidak dikelola.
- ofs
- Int32
Offset byte tambahan, yang ditambahkan ke ptr
parameter sebelum membaca.
Mengembalikan
Bilangan bulat bertanda tangan 64-bit dibaca dari memori tidak terkelola pada offset yang diberikan.
- 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
ReadInt64 memungkinkan interaksi langsung dengan array yang ditandatangani 64-bit yang tidak terkelola, menghilangkan pengeluaran menyalin seluruh array yang tidak dikelola (menggunakan Marshal.Copy) ke array terkelola terpisah sebelum membaca nilai elemennya.
Membaca dari lokasi memori yang tidak sejajar didukung.