Marshal.ReadIntPtr 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í.
Lee un entero de tamaño nativo del procesador de la memoria no administrada. Se admite la lectura desde ubicaciones de memoria no asignadas.
Sobrecargas
| Nombre | Description |
|---|---|
| ReadIntPtr(IntPtr, Int32) |
Lee un entero de tamaño nativo del procesador en un desplazamiento determinado de la memoria no administrada. |
| ReadIntPtr(Object, Int32) |
Obsoletos.
Lee un entero de tamaño nativo del procesador de la memoria no administrada. |
| ReadIntPtr(IntPtr) |
Lee un entero de tamaño nativo del procesador de la memoria no administrada. |
ReadIntPtr(IntPtr, Int32)
Lee un entero de tamaño nativo del procesador en un desplazamiento determinado de la memoria no administrada.
public:
static IntPtr ReadIntPtr(IntPtr ptr, int ofs);
[System.Security.SecurityCritical]
public static IntPtr ReadIntPtr(IntPtr ptr, int ofs);
public static IntPtr ReadIntPtr(IntPtr ptr, int ofs);
[<System.Security.SecurityCritical>]
static member ReadIntPtr : nativeint * int -> nativeint
static member ReadIntPtr : nativeint * int -> nativeint
Public Shared Function ReadIntPtr (ptr As IntPtr, ofs As Integer) As IntPtr
Parámetros
- ptr
-
IntPtr
nativeint
Dirección base en memoria no administrada desde la que se va a leer.
- ofs
- Int32
Desplazamiento de bytes adicional, que se agrega al ptr parámetro antes de leerlo.
Devoluciones
nativeint
Entero leído de la memoria no administrada en el desplazamiento especificado.
- 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
ReadIntPtr 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 leer sus valores de elemento.
Se admite la lectura desde ubicaciones de memoria no asignadas.
Consulte también
Se aplica a
ReadIntPtr(Object, Int32)
Precaución
ReadIntPtr(Object, Int32) may be unavailable in future releases.
Lee un entero de tamaño nativo del procesador de la memoria no administrada.
public:
static IntPtr ReadIntPtr(System::Object ^ ptr, int ofs);
[System.Obsolete("ReadIntPtr(Object, Int32) may be unavailable in future releases.")]
[System.Security.SecurityCritical]
public static IntPtr ReadIntPtr(object ptr, int ofs);
public static IntPtr ReadIntPtr(object ptr, int ofs);
[System.Security.SecurityCritical]
public static IntPtr ReadIntPtr(object ptr, int ofs);
[System.Obsolete("ReadIntPtr(Object, Int32) may be unavailable in future releases.")]
public static IntPtr ReadIntPtr(object ptr, int ofs);
[<System.Obsolete("ReadIntPtr(Object, Int32) may be unavailable in future releases.")>]
[<System.Security.SecurityCritical>]
static member ReadIntPtr : obj * int -> nativeint
static member ReadIntPtr : obj * int -> nativeint
[<System.Security.SecurityCritical>]
static member ReadIntPtr : obj * int -> nativeint
[<System.Obsolete("ReadIntPtr(Object, Int32) may be unavailable in future releases.")>]
static member ReadIntPtr : obj * int -> nativeint
Public Shared Function ReadIntPtr (ptr As Object, ofs As Integer) As IntPtr
Parámetros
- ptr
- Object
Dirección base en memoria no administrada del objeto de origen.
- ofs
- Int32
Desplazamiento de bytes adicional, que se agrega al ptr parámetro antes de leerlo.
Devoluciones
nativeint
Entero leído de la memoria no administrada en el desplazamiento especificado.
- 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
ReadIntPtr 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 leer sus valores de elemento.
Se admite la lectura desde ubicaciones de memoria no asignadas.
Consulte también
Se aplica a
ReadIntPtr(IntPtr)
Lee un entero de tamaño nativo del procesador de la memoria no administrada.
public:
static IntPtr ReadIntPtr(IntPtr ptr);
[System.Security.SecurityCritical]
public static IntPtr ReadIntPtr(IntPtr ptr);
public static IntPtr ReadIntPtr(IntPtr ptr);
[<System.Security.SecurityCritical>]
static member ReadIntPtr : nativeint -> nativeint
static member ReadIntPtr : nativeint -> nativeint
Public Shared Function ReadIntPtr (ptr As IntPtr) As IntPtr
Parámetros
- ptr
-
IntPtr
nativeint
Dirección de la memoria no administrada desde la que se va a leer.
Devoluciones
nativeint
Entero leído de la memoria no administrada. Se devuelve un entero de 32 bits en máquinas de 32 bits y se devuelve un entero de 64 bits en máquinas de 64 bits.
- 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
ReadIntPtr tiene un desplazamiento implícito de 0. Este método 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 leer sus valores de elemento.
Se admite la lectura desde ubicaciones de memoria no asignadas.