Exportar (0) Imprimir
Expandir todo
Expandir Minimizar
Este artículo proviene de un motor de traducción automática. Mueva el puntero sobre las frases del artículo para ver el texto original. Más información.
Traducción
Original

Type.IsLayoutSequential (Propiedad)

Obtiene un valor que indica si los campos del tipo actual se disponen secuencialmente, en el orden que se definieron o emitieron en los metadatos.

Espacio de nombres:  System
Ensamblado:  mscorlib (en mscorlib.dll)

public bool IsLayoutSequential { get; }

Valor de propiedad

Tipo: System.Boolean
true si la propiedad Attributes del tipo actual incluye TypeAttributes.SequentialLayout; en caso contrario, es false.

Implementaciones

_Type.IsLayoutSequential

Esta propiedad se proporciona por motivos de comodidad. Alternativamente, puede utilizar el valor de enumeración de TypeAttributes.LayoutMask para seleccionar los atributos de diseño de tipo, y la prueba si TypeAttributes.SequentialLayout está establecido. TypeAttributes.AutoLayout , TypeAttributes.ExplicitLayout, y los valores de enumeración de TypeAttributes.SequentialLayout indican que la manera los campos de tipo se muestra en memoria.

Para los tipos dinámicos, puede especificar TypeAttributes.SequentialLayout cuando se crea el tipo. En código, aplique el atributo de StructLayoutAttribute con el valor de enumeración de LayoutKind.Sequential el tipo, especificar que el diseño es secuencial.

NotaNota

No puede utilizar el método de GetCustomAttributes para determinar si StructLayoutAttribute se ha aplicado a un tipo.

Para obtener más información, consulte sección 9.1.2 de la especificación de la documentación de Common Language Infrastructure (CLI), "Partition II: Metadata Definition and Semantics". La documentación está disponible en línea; vea ECMA C# and Common Language Infrastructure Standards en MSDN y Standard ECMA-335 - Common Language Infrastructure (CLI) en el sitio web de ECMA International.

Si el objeto Type actual representa un tipo genérico construido, esta propiedad se aplica a la definición de tipo genérico a partir de la cual se ha construido el tipo. Por ejemplo, si el objeto Type actual representa MyGenericType<int> (MyGenericType(Of Integer) en Visual Basic), el valor de esta propiedad viene determinado por MyGenericType<T>.

Si el objeto Type actual representa un parámetro de tipo en la definición de un tipo genérico o de un método genérico, esta propiedad siempre devuelve false.

El ejemplo siguiente se crea una instancia de una clase cuyo valor de enumeración de LayoutKind.Sequential en la clase de StructLayoutAttribute se ha establecido, comprueba la propiedad de IsLayoutSequential , y muestra el resultado.


using System;
using System.Reflection;
using System.ComponentModel;
using System.Runtime.InteropServices;
class MyTypeSequential1
{
}
[StructLayoutAttribute(LayoutKind.Sequential)]
class MyTypeSequential2
{
    public static void Main(string []args)
    {
        try
        {
            // Create an instance of myTypeSeq1.
            MyTypeSequential1 myObj1 = new MyTypeSequential1();
            Type myTypeObj1 = myObj1.GetType();
            // Check for and display the SequentialLayout attribute.
            Console.WriteLine("\nThe object myObj1 has IsLayoutSequential: {0}.", myObj1.GetType().IsLayoutSequential);
            // Create an instance of 'myTypeSeq2' class.
            MyTypeSequential2 myObj2 = new MyTypeSequential2();
            Type myTypeObj2 = myObj2.GetType();
            // Check for and display the SequentialLayout attribute.
            Console.WriteLine("\nThe object myObj2 has IsLayoutSequential: {0}.", myObj2.GetType().IsLayoutSequential);
        }
        catch(Exception e)
        {
            Console.WriteLine("\nAn exception occurred: {0}", e.Message);
        }
    }
}


.NET Framework

Compatible con: 4.5.2, 4.5.1, 4.5, 4, 3.5, 3.0, 2.0, 1.1, 1.0

.NET Framework Client Profile

Compatible con: 4, 3.5 SP1

.NET para aplicaciones de Windows Phone

Compatible con: Windows Phone 8, Silverlight 8.1

Windows Phone 8.1, Windows Phone 8, Windows 8.1, Windows Server 2012 R2, Windows 8, Windows Server 2012, Windows 7, Windows Vista SP2, Windows Server 2008 (no se admite el rol Server Core), Windows Server 2008 R2 (se admite el rol Server Core con SP1 o versiones posteriores; no se admite Itanium)

.NET Framework no admite todas las versiones de todas las plataformas. Para obtener una lista de las versiones compatibles, vea Requisitos de sistema de .NET Framework.

Adiciones de comunidad

AGREGAR
Mostrar:
© 2014 Microsoft