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.IsGenericParameter (Propiedad)

Obtiene un valor que indica si el objeto Type actual representa un parámetro de tipo en la definición de un método o tipo genérico.

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

public virtual bool IsGenericParameter { get; }

Valor de propiedad

Tipo: System.Boolean
true si el objeto Type representa un parámetro de tipo de una definición de tipo genérico o de una definición de método genérico; de lo contrario, false.

Los objetos Type que representan parámetros de tipo genérico se pueden obtener llamando al método GetGenericArguments de un objeto Type que representa una definición de tipo genérico o al método GetGenericArguments de un objeto MethodInfo que representa una definición de método genérico.

  • En el caso de una definición de método o de tipo genérico, la propiedad IsGenericParameter devuelve true para todos los elementos de la matriz resultante.

  • En el caso de un método o tipo construido cerrado, la propiedad IsGenericParameter devuelve false para todos los elementos de la matriz devuelta por el método GetGenericArguments.

  • En el caso de un tipo o método construido abierto, algunos elementos de la matriz podrían ser tipos específicos y otros podrían ser parámetros de tipo. IsGenericParameter devuelve false para los tipos y true para los parámetros de tipo. En el ejemplo de código de la propiedad ContainsGenericParameters se muestra una clase genérica con una mezcla de tipos y parámetros de tipo.

Si desea obtener una lista de las condiciones invariables para términos que se utilizan en la reflexión genérica, vea los comentarios de la propiedad IsGenericType.

En el ejemplo siguiente se utiliza la propiedad IsGenericParameter para comprobar los parámetros de tipo genérico en un tipo genérico.


if (t.IsGenericType)
{
    // If this is a generic type, display the type arguments.
    //
    Type[] typeArguments = t.GetGenericArguments();

    Console.WriteLine("\tList type arguments ({0}):", 
        typeArguments.Length);

    foreach (Type tParam in typeArguments)
    {
        // If this is a type parameter, display its
        // position.
        //
        if (tParam.IsGenericParameter)
        {
            Console.WriteLine("\t\t{0}\t(unassigned - parameter position {1})",
                tParam,
                tParam.GenericParameterPosition);
        }
        else
        {
            Console.WriteLine("\t\t{0}", tParam);
        }
    }
}


.NET Framework

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

.NET Framework Client Profile

Compatible con: 4, 3.5 SP1

Biblioteca de clases portable

Compatible con: Biblioteca de clases portable

.NET para aplicaciones de la Tienda Windows

Compatible con: Windows 8

.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