Marshal.WriteInt16 Método

Definición

Escribe un valor entero de 16 bits con signo en la memoria no administrada. Se admite la escritura en ubicaciones de memoria desalineadas.

Sobrecargas

WriteInt16(IntPtr, Char)

Escribe un carácter como un valor entero de 16 bits en la memoria no administrada.

WriteInt16(IntPtr, Int16)

Escribe un valor entero de 16 bits en la memoria no administrada.

WriteInt16(IntPtr, Int32, Char)

Escribe un valor entero de 16 bits con signo en la memoria no administrada en un desplazamiento especificado.

WriteInt16(IntPtr, Int32, Int16)

Escribe un valor entero de 16 bits con signo en la memoria no administrada en un desplazamiento especificado.

WriteInt16(Object, Int32, Char)
Obsoletos.

Escribe un valor entero de 16 bits con signo en la memoria no administrada en un desplazamiento especificado.

WriteInt16(Object, Int32, Int16)
Obsoletos.

Escribe un valor entero de 16 bits con signo en la memoria no administrada en un desplazamiento especificado.

WriteInt16(IntPtr, Char)

Source:
Marshal.cs
Source:
Marshal.cs
Source:
Marshal.cs

Escribe un carácter como un valor entero de 16 bits en la memoria no administrada.

C#
[System.Security.SecurityCritical]
public static void WriteInt16(IntPtr ptr, char val);
C#
public static void WriteInt16(IntPtr ptr, char val);

Parámetros

ptr
IntPtr

Dirección de la memoria no administrada en la que se va a escribir.

val
Char

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 ReadInt16 métodos y WriteInt16 .

C#
static void ReadWriteInt16()
{
    // Allocate unmanaged memory. 
    int elementSize = 2;
    IntPtr unmanagedArray = Marshal.AllocHGlobal(10 * elementSize);

    // Set the 10 elements of the C-style unmanagedArray
    for (int i = 0; i < 10; i++)
    {
        Marshal.WriteInt16(unmanagedArray, i * elementSize, ((Int16)(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.ReadInt16(unmanagedArray, i * elementSize));
    }

    Marshal.FreeHGlobal(unmanagedArray);

    Console.WriteLine("Done. Press Enter to continue.");
    Console.ReadLine();
}

Comentarios

WriteInt16 permite la interacción directa con una matriz firmada de 16 bits 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 desalineadas.

Consulte también

Se aplica a

.NET 9 e outras versións
Produto Versións
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0

WriteInt16(IntPtr, Int16)

Source:
Marshal.cs
Source:
Marshal.cs
Source:
Marshal.cs

Escribe un valor entero de 16 bits en la memoria no administrada.

C#
[System.Security.SecurityCritical]
public static void WriteInt16(IntPtr ptr, short val);
C#
public static void WriteInt16(IntPtr ptr, short val);

Parámetros

ptr
IntPtr

Dirección de la memoria no administrada en la que se va a escribir.

val
Int16

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 ReadInt16 métodos y WriteInt16 .

C#
static void ReadWriteInt16()
{
    // Allocate unmanaged memory. 
    int elementSize = 2;
    IntPtr unmanagedArray = Marshal.AllocHGlobal(10 * elementSize);

    // Set the 10 elements of the C-style unmanagedArray
    for (int i = 0; i < 10; i++)
    {
        Marshal.WriteInt16(unmanagedArray, i * elementSize, ((Int16)(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.ReadInt16(unmanagedArray, i * elementSize));
    }

    Marshal.FreeHGlobal(unmanagedArray);

    Console.WriteLine("Done. Press Enter to continue.");
    Console.ReadLine();
}

Comentarios

WriteInt16 permite la interacción directa con una matriz firmada de 16 bits 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 desalineadas.

Consulte también

Se aplica a

.NET 9 e outras versións
Produto Versións
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0

WriteInt16(IntPtr, Int32, Char)

Source:
Marshal.cs
Source:
Marshal.cs
Source:
Marshal.cs

Escribe un valor entero de 16 bits con signo en la memoria no administrada en un desplazamiento especificado.

C#
[System.Security.SecurityCritical]
public static void WriteInt16(IntPtr ptr, int ofs, char val);
C#
public static void WriteInt16(IntPtr ptr, int ofs, char val);

Parámetros

ptr
IntPtr

Dirección base del montón nativo en la que se va a escribir.

ofs
Int32

Desplazamiento de bytes adicional, que se agrega al parámetro ptr antes de la escritura.

val
Char

Valor que se va a escribir.

Atributos

Excepciones

La dirección base (ptr) más el byte de desplazamiento (ofs) produce un valor null o una dirección no válida.

Ejemplos

En el ejemplo siguiente se muestra cómo leer y escribir en una matriz no administrada mediante los ReadInt16 métodos y WriteInt16 .

C#
static void ReadWriteInt16()
{
    // Allocate unmanaged memory. 
    int elementSize = 2;
    IntPtr unmanagedArray = Marshal.AllocHGlobal(10 * elementSize);

    // Set the 10 elements of the C-style unmanagedArray
    for (int i = 0; i < 10; i++)
    {
        Marshal.WriteInt16(unmanagedArray, i * elementSize, ((Int16)(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.ReadInt16(unmanagedArray, i * elementSize));
    }

    Marshal.FreeHGlobal(unmanagedArray);

    Console.WriteLine("Done. Press Enter to continue.");
    Console.ReadLine();
}

Comentarios

WriteInt16 permite la interacción directa con una matriz firmada de 16 bits 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 desalineadas.

Consulte también

Se aplica a

.NET 9 e outras versións
Produto Versións
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0

WriteInt16(IntPtr, Int32, Int16)

Source:
Marshal.cs
Source:
Marshal.cs
Source:
Marshal.cs

Escribe un valor entero de 16 bits con signo en la memoria no administrada en un desplazamiento especificado.

C#
[System.Security.SecurityCritical]
public static void WriteInt16(IntPtr ptr, int ofs, short val);
C#
public static void WriteInt16(IntPtr ptr, int ofs, short val);

Parámetros

ptr
IntPtr

Dirección base de la memoria no administrada en la que se va a escribir.

ofs
Int32

Desplazamiento de bytes adicional, que se agrega al parámetro ptr antes de la escritura.

val
Int16

Valor que se va a escribir.

Atributos

Excepciones

La dirección base (ptr) más el byte de desplazamiento (ofs) produce un valor null o una dirección no válida.

Ejemplos

En el ejemplo siguiente se muestra cómo leer y escribir en una matriz no administrada mediante los ReadInt16 métodos y WriteInt16 .

C#
static void ReadWriteInt16()
{
    // Allocate unmanaged memory. 
    int elementSize = 2;
    IntPtr unmanagedArray = Marshal.AllocHGlobal(10 * elementSize);

    // Set the 10 elements of the C-style unmanagedArray
    for (int i = 0; i < 10; i++)
    {
        Marshal.WriteInt16(unmanagedArray, i * elementSize, ((Int16)(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.ReadInt16(unmanagedArray, i * elementSize));
    }

    Marshal.FreeHGlobal(unmanagedArray);

    Console.WriteLine("Done. Press Enter to continue.");
    Console.ReadLine();
}

Comentarios

WriteInt16 permite la interacción directa con una matriz firmada de 16 bits 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 desalineadas.

Consulte también

Se aplica a

.NET 9 e outras versións
Produto Versións
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0

WriteInt16(Object, Int32, Char)

Source:
Marshal.cs
Source:
Marshal.cs
Source:
Marshal.cs

Precaución

WriteInt16(Object, Int32, Char) may be unavailable in future releases.

Escribe un valor entero de 16 bits con signo en la memoria no administrada en un desplazamiento especificado.

C#
[System.Obsolete("WriteInt16(Object, Int32, Char) may be unavailable in future releases.")]
[System.Security.SecurityCritical]
public static void WriteInt16(object ptr, int ofs, char val);
C#
[System.Obsolete("WriteInt16(Object, Int32, Char) may be unavailable in future releases.")]
public static void WriteInt16(object ptr, int ofs, char val);
C#
public static void WriteInt16(object ptr, int ofs, char val);
C#
[System.Security.SecurityCritical]
public static void WriteInt16(object ptr, int ofs, char val);

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 parámetro ptr antes de la escritura.

val
Char

Valor que se va a escribir.

Atributos

Excepciones

La dirección base (ptr) más el byte de desplazamiento (ofs) produce un valor null o una dirección no válida.

ptr es un objeto ArrayWithOffset. Este método no acepta parámetros ArrayWithOffset.

Comentarios

WriteInt16 permite la interacción directa con una matriz firmada de 16 bits 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 desalineadas.

Consulte también

Se aplica a

.NET 9 e outras versións
Produto Versións (Obsoleto)
.NET (Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9)
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1 (4.7 (package-provided), 4.7.1 (package-provided), 4.7.2 (package-provided), 4.8 (package-provided))
.NET Standard 1.1, 2.0 (1.2, 1.3, 1.4, 1.5, 1.6, 2.1)
UWP (10.0)

WriteInt16(Object, Int32, Int16)

Source:
Marshal.CoreCLR.cs
Source:
Marshal.CoreCLR.cs
Source:
Marshal.CoreCLR.cs

Precaución

WriteInt16(Object, Int32, Int16) may be unavailable in future releases.

Escribe un valor entero de 16 bits con signo en la memoria no administrada en un desplazamiento especificado.

C#
[System.Obsolete("WriteInt16(Object, Int32, Int16) may be unavailable in future releases.")]
[System.Security.SecurityCritical]
public static void WriteInt16(object ptr, int ofs, short val);
C#
[System.Obsolete("WriteInt16(Object, Int32, Int16) may be unavailable in future releases.")]
public static void WriteInt16(object ptr, int ofs, short val);
C#
public static void WriteInt16(object ptr, int ofs, short val);
C#
[System.Security.SecurityCritical]
public static void WriteInt16(object ptr, int ofs, short val);

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 parámetro ptr antes de la escritura.

val
Int16

Valor que se va a escribir.

Atributos

Excepciones

La dirección base (ptr) más el byte de desplazamiento (ofs) produce un valor null o una dirección no válida.

ptr es un objeto ArrayWithOffset. Este método no acepta parámetros ArrayWithOffset.

Comentarios

WriteInt16 permite la interacción directa con una matriz firmada de 16 bits 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 desalineadas.

Consulte también

Se aplica a

.NET 9 e outras versións
Produto Versións (Obsoleto)
.NET (Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9)
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1 (4.7 (package-provided), 4.7.1 (package-provided), 4.7.2 (package-provided), 4.8 (package-provided))
.NET Standard 1.1, 2.0 (1.2, 1.3, 1.4, 1.5, 1.6, 2.1)
UWP (10.0)