Bagikan melalui


Marshal.WriteInt64 Metode

Definisi

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.

ptrArrayWithOffset 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-

ptradalah 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.

Lihat juga

Berlaku untuk