Lire en anglais

Partager via


LayoutKind Énumération

Définition

Contrôle la disposition d'un objet exporté vers du code non managé.

C#
public enum LayoutKind
C#
[System.Serializable]
public enum LayoutKind
C#
[System.Serializable]
[System.Runtime.InteropServices.ComVisible(true)]
public enum LayoutKind
Héritage
LayoutKind
Attributs

Champs

Nom Valeur Description
Auto 3

Le runtime sélectionne automatiquement une disposition appropriée pour les membres d'un objet en mémoire non managée. Les objets définis avec ce membre d'énumération ne peuvent être exposés en dehors du code managé. Une telle tentative génère une exception.

Explicit 2

La position précise de chaque membre d'un objet dans la mémoire non managée est explicitement contrôlée, en fonction du paramètre du champ Pack. Chaque membre doit utiliser FieldOffsetAttribute pour indiquer la position de ce champ dans le type.

Sequential 0

Les membres de l'objet sont disposés séquentiellement, en respectant l'ordre dans lequel ils apparaissent lors de l'exportation dans la mémoire non managée. Les membres sont disposés selon la compression spécifiée dans Pack et peuvent être non contigus.

Exemples

L’exemple suivant montre la déclaration managée de la PtInRect fonction, qui vérifie si un point se trouve dans un rectangle et définit une structure avec une Point disposition séquentielle et une structure avec une Rect disposition explicite.

C#
enum Bool
{
   False = 0,
   True
};
[StructLayout(LayoutKind.Sequential)]
public struct Point
{
   public int x;
   public int y;
}

[StructLayout(LayoutKind.Explicit)]
public struct Rect
{
   [FieldOffset(0)] public int left;
   [FieldOffset(4)] public int top;
   [FieldOffset(8)] public int right;
   [FieldOffset(12)] public int bottom;
}

internal static class NativeMethods
{
   [DllImport("user32.dll", CallingConvention=CallingConvention.StdCall)]
   internal static extern Bool PtInRect(ref Rect r, Point p);
};

class TestApplication
{
   public static void Main()
   {
      try
      {
         Bool bPointInRect = 0;
         Rect myRect = new Rect();
         myRect.left = 10;
         myRect.right = 100;
         myRect.top = 10;
         myRect.bottom = 100;
         Point myPoint = new Point();
         myPoint.x = 50;
         myPoint.y = 50;
         bPointInRect = NativeMethods.PtInRect(ref myRect, myPoint);
         if(bPointInRect == Bool.True)
            Console.WriteLine("Point lies within the Rect");
         else
            Console.WriteLine("Point did not lie within the Rect");
      }
      catch(Exception e)
      {
         Console.WriteLine("Exception : " + e.Message);
      }
   }
}

Remarques

Cette énumération est utilisée avec StructLayoutAttribute. Le Common Language Runtime utilise la valeur de Auto disposition par défaut. Pour réduire les problèmes liés à la disposition associés à la valeur, les Auto compilateurs C#, Visual Basic et C++ spécifient Sequential la disposition pour les types de valeurs.

Important

Le StructLayoutAttribute.Pack champ contrôle l’alignement des champs de données et affecte donc la disposition, quelle que soit la LayoutKind valeur que vous spécifiez. Par défaut, la valeur de Pack est 0, ce qui indique la taille d’empaquetage par défaut pour la plateforme actuelle. Par exemple, lorsque vous utilisez la Explicit valeur de disposition et que vous spécifiez des alignements de champs sur des limites d’octets, vous devez définir Pack sur 1 pour obtenir le résultat souhaité.

S’applique à

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.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0