Číst v angličtině

Sdílet prostřednictvím


GenericParameterAttributes Výčet

Definice

Popisuje omezení obecného typu parametru obecného typu nebo metody.

Tento výčet podporuje bitové kombinace hodnot jeho členů.

C#
[System.Flags]
public enum GenericParameterAttributes
Dědičnost
GenericParameterAttributes
Atributy

Pole

Name Hodnota Description
AllowByRefLike 32

Parametr obecného typu může být ByRefLike.

Contravariant 2

Parametr obecného typu je kontravariantní. Parametr kontravariantního typu se může zobrazit jako typ parametru v podpisech metody.

Covariant 1

Parametr obecného typu je kovariantní. Kovariantní parametr typu se může objevit jako typ výsledku metody, typ pole jen pro čtení, deklarovaný základní typ nebo implementované rozhraní.

DefaultConstructorConstraint 16

Typ lze nahradit parametrem obecného typu pouze v případě, že má konstruktor bez parametrů.

None 0

Neexistují žádné zvláštní příznaky.

NotNullableValueTypeConstraint 8

Typ může být nahrazen parametrem obecného typu pouze v případě, že se jedná o typ hodnoty a není nullable.

ReferenceTypeConstraint 4

Typ lze nahradit parametrem obecného typu pouze v případě, že se jedná o odkazový typ.

SpecialConstraintMask 28

Vybere kombinaci všech speciálních příznaků omezení. Tato hodnota je výsledkem použití logického operátoru OR ke kombinování následujících příznaků: DefaultConstructorConstraint, ReferenceTypeConstrainta NotNullableValueTypeConstraint.

VarianceMask 3

Vybere kombinaci všech příznaků rozptylu. Tato hodnota je výsledkem použití logického operátoru OR ke kombinování následujících příznaků: Contravariant a Covariant.

Příklady

Následující příklad kódu definuje obecný typ Test se dvěma parametry typu. Druhý parametr typu má omezení základní třídy a omezení typu odkazu. Při spuštění programu se omezení prověří pomocí vlastnosti Type.GenericParameterAttributes a metody Type.GetGenericParameterConstraints.

C#
using System;
using System.Reflection;

// Define a sample interface to use as an interface constraint.
public interface ITest {}

// Define a base type to use as a base class constraint.
public class Base {}

// Define the generic type to examine. The first generic type parameter,
// T, derives from the class Base and implements ITest. This demonstrates
// a base class constraint and an interface constraint. The second generic 
// type parameter, U, must be a reference type (class) and must have a 
// default constructor (new()). This demonstrates special constraints.
//
public class Test<T,U> 
    where T : Base, ITest 
    where U : class, new() {}

// Define a type that derives from Base and implements ITest. This type
// satisfies the constraints on T in class Test.
public class Derived : Base, ITest {}

public class Example
{
    public static void Main()
    {
        // To get the generic type definition, omit the type
        // arguments but retain the comma to indicate the number
        // of type arguments. 
        //
        Type def = typeof(Test<,>);
        Console.WriteLine("\r\nExamining generic type {0}", def);

        // Get the type parameters of the generic type definition,
        // and display them.
        //
        Type[] defparams = def.GetGenericArguments();
        foreach (Type tp in defparams)
        {
            Console.WriteLine("\r\nType parameter: {0}", tp.Name);
            Console.WriteLine("\t{0}", 
                ListGenericParameterAttributes(tp));

            // List the base class and interface constraints. The
            // constraints are returned in no particular order. If 
            // there are no class or interface constraints, an empty
            // array is returned.
            //
            Type[] tpConstraints = tp.GetGenericParameterConstraints();
            foreach (Type tpc in tpConstraints)
            {
                Console.WriteLine("\t{0}", tpc);
            }
        }
    }

    // List the variance and special constraint flags. 
    //
    private static string ListGenericParameterAttributes(Type t)
    {
        string retval;
        GenericParameterAttributes gpa = t.GenericParameterAttributes;
        GenericParameterAttributes variance = gpa & 
            GenericParameterAttributes.VarianceMask;

        // Select the variance flags.
        if (variance == GenericParameterAttributes.None)
        {
            retval = "No variance flag;";
        }
        else
        {
            if ((variance & GenericParameterAttributes.Covariant) != 0)
                retval = "Covariant;";
            else
                retval = "Contravariant;";
        }

        // Select 
        GenericParameterAttributes constraints = gpa & 
            GenericParameterAttributes.SpecialConstraintMask;

        if (constraints == GenericParameterAttributes.None)
        {
            retval += " No special constraints";
        }
        else
        {
            if ((constraints & GenericParameterAttributes.ReferenceTypeConstraint) != 0)
                retval += " ReferenceTypeConstraint";
            if ((constraints & GenericParameterAttributes.NotNullableValueTypeConstraint) != 0)
                retval += " NotNullableValueTypeConstraint";
            if ((constraints & GenericParameterAttributes.DefaultConstructorConstraint) != 0)
                retval += " DefaultConstructorConstraint";
        }

        return retval;
    }
}
/* This example produces the following output:

Examining generic type Test`2[T,U]

Type parameter: T
        No variance flag; no special constraints.
        Base
        ITest

Type parameter: U
        No variance flag; ReferenceTypeConstraint DefaultConstructorConstraint
 */

Poznámky

Členy GenericParameterAttributes výčtu jsou rozděleny do dvou skupin, skupiny rozptylu a zvláštní skupiny omezení. Chcete-li otestovat hodnotu GenericParameterAttributes pro příznaky rozptylu, nejprve proveďte bitové operace AND s varianceMask. Pokud je výsledkem Žádný, nejsou žádné příznaky odchylky. Podobně použijte SpeciálníConstraintMask k otestování pro příznaky omezení.

Platí pro

Produkt Verze
.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 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.6, 2.0, 2.1
UWP 10.0