Ler en inglés

Compartir por


LayoutKind Enumeración

Definición

Controla el diseño de un objeto cuando se lo exporta a un código no administrado.

C#
public enum LayoutKind
C#
[System.Serializable]
public enum LayoutKind
C#
[System.Serializable]
[System.Runtime.InteropServices.ComVisible(true)]
public enum LayoutKind
Herencia
LayoutKind
Atributos

Campos

Nombre Valor Description
Auto 3

El motor en tiempo de ejecución elige un diseño apropiado para los miembros de un objeto en la memoria no administrada. Los objetos definidos con este miembro de enumeración no se pueden exponer fuera del código administrado. Si se intenta hacer esto, se genera una excepción.

Explicit 2

La posición exacta de cada miembro de un objeto en memoria no administrada se controla explícitamente, sujeta al valor del campo Pack. Cada miembro debe utilizar FieldOffsetAttribute para indicar la posición del campo dentro del tipo.

Sequential 0

Los miembros del objeto se disponen secuencialmente, en el orden en que aparecen cuando se exporta a la memoria no administrada. Los miembros se disponen de acuerdo con el empaquetado especificado en Pack y pueden no ser contiguos.

Ejemplos

En el ejemplo siguiente se muestra la declaración administrada de la PtInRect función , que comprueba si un punto se encuentra dentro de un rectángulo y define una Point estructura con diseño secuencial y una Rect estructura con diseño explícito.

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

Comentarios

Esta enumeración se usa con StructLayoutAttribute. Common Language Runtime usa el valor de Auto diseño de forma predeterminada. Para reducir los problemas relacionados con el Auto diseño asociados al valor, los compiladores de C#, Visual Basic y C++ especifican Sequential el diseño de los tipos de valor.

Importante

El StructLayoutAttribute.Pack campo controla la alineación de los campos de datos y, por tanto, afecta al diseño independientemente del LayoutKind valor especificado. De forma predeterminada, el valor de Pack es 0, que indica el tamaño de empaquetado predeterminado para la plataforma actual. Por ejemplo, cuando se usa el valor de Explicit diseño y se especifican las alineaciones de campo en los límites de bytes, debe establecer en Pack 1 para obtener el resultado deseado.

Se aplica a

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