Marshal.WriteIntPtr Método
Definición
Importante
Parte de la información hace referencia a la versión preliminar del producto, que puede haberse modificado sustancialmente antes de lanzar la versión definitiva. Microsoft no otorga ninguna garantía, explícita o implícita, con respecto a la información proporcionada aquí.
Escribe un valor entero de tamaño nativo del procesador en memoria no administrada. Los enteros de 32 bits se escriben en sistemas de 32 bits y los enteros de 64 bits se escriben en sistemas de 64 bits. Se admite la escritura en ubicaciones de memoria no asignadas.
Sobrecargas
| Nombre | Description |
|---|---|
| WriteIntPtr(IntPtr, IntPtr) |
Escribe un valor entero de tamaño nativo del procesador en memoria no administrada. |
| WriteIntPtr(IntPtr, Int32, IntPtr) |
Escribe un valor entero de tamaño nativo del procesador en memoria no administrada en un desplazamiento especificado. |
| WriteIntPtr(Object, Int32, IntPtr) |
Obsoletos.
Escribe un valor entero de tamaño nativo del procesador en memoria no administrada. |
WriteIntPtr(IntPtr, IntPtr)
Escribe un valor entero de tamaño nativo del procesador en memoria no administrada.
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)
Parámetros
- ptr
-
IntPtr
nativeint
Dirección en la memoria no administrada en la que se va a escribir.
- val
-
IntPtr
nativeint
Valor que se va a escribir.
- Atributos
Excepciones
ptr no es un formato reconocido.
O bien
ptr es null.
O bien
ptr no es válido.
Ejemplos
En el ejemplo siguiente se muestra cómo leer y escribir en una matriz no administrada mediante los ReadIntPtr métodos y 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
Comentarios
WriteIntPtr permite la interacción directa con una matriz de estilo IntPtr C no administrada, lo que elimina el gasto de copiar una matriz no administrada completa (mediante Marshal.Copy) en una matriz administrada independiente antes de establecer sus valores de elemento.
Se admite la escritura en ubicaciones de memoria no asignadas.
Consulte también
Se aplica a
WriteIntPtr(IntPtr, Int32, IntPtr)
Escribe un valor entero de tamaño nativo del procesador en memoria no administrada en un desplazamiento especificado.
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)
Parámetros
- ptr
-
IntPtr
nativeint
Dirección base en la memoria no administrada en la que se va a escribir.
- ofs
- Int32
Desplazamiento de bytes adicional, que se agrega al ptr parámetro antes de escribir.
- val
-
IntPtr
nativeint
Valor que se va a escribir.
- Atributos
Excepciones
La dirección base (ptr) más el byte de desplazamiento (ofs) genera una dirección nula o no válida.
Ejemplos
En el ejemplo siguiente se muestra cómo leer y escribir en una matriz no administrada mediante los ReadIntPtr métodos y 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
Comentarios
Este método escribe un entero de 32 bits en sistemas de 32 bits y un entero de 64 bits en sistemas de 64 bits.
WriteIntPtr permite la interacción directa con una matriz de estilo IntPtr C no administrada, lo que elimina el gasto de copiar una matriz no administrada completa (mediante Marshal.Copy) en una matriz administrada independiente antes de establecer sus valores de elemento.
Se admite la escritura en ubicaciones de memoria no asignadas.
Consulte también
Se aplica a
WriteIntPtr(Object, Int32, IntPtr)
Precaución
WriteIntPtr(Object, Int32, IntPtr) may be unavailable in future releases.
Escribe un valor entero de tamaño nativo del procesador en memoria no administrada.
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);
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.")]
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
static member WriteIntPtr : obj * int * nativeint -> unit
[<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
Public Shared Sub WriteIntPtr (ptr As Object, ofs As Integer, val As IntPtr)
Parámetros
- ptr
- Object
Dirección base en la memoria no administrada del objeto de destino.
- ofs
- Int32
Desplazamiento de bytes adicional, que se agrega al ptr parámetro antes de escribir.
- val
-
IntPtr
nativeint
Valor que se va a escribir.
- Atributos
Excepciones
La dirección base (ptr) más el byte de desplazamiento (ofs) genera una dirección nula o no válida.
ptr es un ArrayWithOffset objeto . Este método no acepta ArrayWithOffset parámetros.
Comentarios
WriteIntPtr permite la interacción directa con una matriz de bytes de estilo C no administrada, lo que elimina el gasto de copiar una matriz no administrada completa (mediante Marshal.Copy) en una matriz administrada independiente antes de establecer sus valores de elemento.
Se admite la escritura en ubicaciones de memoria no asignadas.