Marshal.WriteInt16 Méthode

Définition

Écrit une valeur d'entier 16 bits signé dans la mémoire non managée. L'écriture dans la mémoire non alignée est prise en charge.

Surcharges

WriteInt16(IntPtr, Char)

Écrit un caractère en tant que valeur entière 16 bits dans la mémoire non managée.

WriteInt16(IntPtr, Int16)

Écrit une valeur entière 16 bits dans la mémoire non managée.

WriteInt16(IntPtr, Int32, Char)

Écrit une valeur entière signée 16 bits dans la mémoire non managée à un offset spécifié.

WriteInt16(IntPtr, Int32, Int16)

Écrit une valeur entière signée 16 bits dans la mémoire non managée à l'offset spécifié.

WriteInt16(Object, Int32, Char)
Obsolète.

Écrit une valeur entière signée 16 bits dans la mémoire non managée à un offset spécifié.

WriteInt16(Object, Int32, Int16)
Obsolète.

Écrit une valeur entière signée 16 bits dans la mémoire non managée à un offset spécifié.

WriteInt16(IntPtr, Char)

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

Écrit un caractère en tant que valeur entière 16 bits dans la mémoire non managée.

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

Paramètres

ptr
IntPtr

Adresse où écrire dans la mémoire non managée.

val
Char

Valeur à écrire.

Attributs

Exceptions

ptr n'est pas un format reconnu.

- ou -

ptr a la valeur null.

- ou -

ptr n'est pas valide.

Exemples

L’exemple suivant montre comment lire et écrire dans un tableau non managé à l’aide des ReadInt16 méthodes et 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();
}

Remarques

WriteInt16 permet l’interaction directe avec un tableau signé 16 bits non managé, éliminant les frais de copie d’un tableau non managé entier (à l’aide Marshal.Copyde ) dans un tableau managé distinct avant de définir ses valeurs d’élément.

L'écriture dans la mémoire non alignée est prise en charge.

Voir aussi

S’applique à

.NET 9 et autres versions
Produit Versions
.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

Écrit une valeur entière 16 bits dans la mémoire non managée.

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

Paramètres

ptr
IntPtr

Adresse où écrire dans la mémoire non managée.

val
Int16

Valeur à écrire.

Attributs

Exceptions

ptr n'est pas un format reconnu.

- ou -

ptr a la valeur null.

- ou -

ptr n'est pas valide.

Exemples

L’exemple suivant montre comment lire et écrire dans un tableau non managé à l’aide des ReadInt16 méthodes et 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();
}

Remarques

WriteInt16 permet l’interaction directe avec un tableau signé 16 bits non managé, éliminant les frais de copie d’un tableau non managé entier (à l’aide Marshal.Copyde ) dans un tableau managé distinct avant de définir ses valeurs d’élément.

L'écriture dans la mémoire non alignée est prise en charge.

Voir aussi

S’applique à

.NET 9 et autres versions
Produit Versions
.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

Écrit une valeur entière signée 16 bits dans la mémoire non managée à un offset spécifié.

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);

Paramètres

ptr
IntPtr

Adresse de base où écrire dans le tas natif.

ofs
Int32

Offset d'octet supplémentaire, qui est ajouté au paramètre ptr avant l'écriture.

val
Char

Valeur à écrire.

Attributs

Exceptions

L'adresse de base (ptr) plus l'octet d'offset (ofs) produisent une adresse null ou non valide.

Exemples

L’exemple suivant montre comment lire et écrire dans un tableau non managé à l’aide des ReadInt16 méthodes et 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();
}

Remarques

WriteInt16 permet l’interaction directe avec un tableau signé 16 bits non managé, éliminant les frais de copie d’un tableau non managé entier (à l’aide Marshal.Copyde ) dans un tableau managé distinct avant de définir ses valeurs d’élément.

L'écriture dans la mémoire non alignée est prise en charge.

Voir aussi

S’applique à

.NET 9 et autres versions
Produit Versions
.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

Écrit une valeur entière signée 16 bits dans la mémoire non managée à l'offset spécifié.

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);

Paramètres

ptr
IntPtr

Adresse de base où écrire dans la mémoire non managée.

ofs
Int32

Offset d'octet supplémentaire, qui est ajouté au paramètre ptr avant l'écriture.

val
Int16

Valeur à écrire.

Attributs

Exceptions

L'adresse de base (ptr) plus l'octet d'offset (ofs) produisent une adresse null ou non valide.

Exemples

L’exemple suivant montre comment lire et écrire dans un tableau non managé à l’aide des ReadInt16 méthodes et 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();
}

Remarques

WriteInt16 permet l’interaction directe avec un tableau signé 16 bits non managé, éliminant les frais de copie d’un tableau non managé entier (à l’aide Marshal.Copyde ) dans un tableau managé distinct avant de définir ses valeurs d’élément.

L'écriture dans la mémoire non alignée est prise en charge.

Voir aussi

S’applique à

.NET 9 et autres versions
Produit Versions
.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

Attention

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

Écrit une valeur entière signée 16 bits dans la mémoire non managée à un offset spécifié.

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);

Paramètres

ptr
Object

Adresse de base dans la mémoire non managée de l'objet cible.

ofs
Int32

Offset d'octet supplémentaire, qui est ajouté au paramètre ptr avant l'écriture.

val
Char

Valeur à écrire.

Attributs

Exceptions

L'adresse de base (ptr) plus l'octet d'offset (ofs) produisent une adresse null ou non valide.

ptr est un objet ArrayWithOffset. Cette méthode n'accepte pas les paramètres ArrayWithOffset.

Remarques

WriteInt16 permet l’interaction directe avec un tableau signé 16 bits non managé, éliminant les frais de copie d’un tableau non managé entier (à l’aide Marshal.Copyde ) dans un tableau managé distinct avant de définir ses valeurs d’élément.

L'écriture dans la mémoire non alignée est prise en charge.

Voir aussi

S’applique à

.NET 9 et autres versions
Produit Versions (Obsolète)
.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

Attention

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

Écrit une valeur entière signée 16 bits dans la mémoire non managée à un offset spécifié.

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);

Paramètres

ptr
Object

Adresse de base dans la mémoire non managée de l'objet cible.

ofs
Int32

Offset d'octet supplémentaire, qui est ajouté au paramètre ptr avant l'écriture.

val
Int16

Valeur à écrire.

Attributs

Exceptions

L'adresse de base (ptr) plus l'octet d'offset (ofs) produisent une adresse null ou non valide.

ptr est un objet ArrayWithOffset. Cette méthode n'accepte pas les paramètres ArrayWithOffset.

Remarques

WriteInt16 permet l’interaction directe avec un tableau signé 16 bits non managé, éliminant les frais de copie d’un tableau non managé entier (à l’aide Marshal.Copyde ) dans un tableau managé distinct avant de définir ses valeurs d’élément.

L'écriture dans la mémoire non alignée est prise en charge.

Voir aussi

S’applique à

.NET 9 et autres versions
Produit Versions (Obsolète)
.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)