英語で読む

次の方法で共有


GenericParameterAttributes 列挙型

定義

ジェネリック型またはメソッドのジェネリック型パラメーターに対する制約について説明します。

この列挙体は、メンバー値のビットごとの組み合わせをサポートしています。

C#
[System.Flags]
public enum GenericParameterAttributes
継承
GenericParameterAttributes
属性

フィールド

名前 説明
AllowByRefLike 32

ジェネリック型パラメーターを ByRefLikeできます。

Contravariant 2

ジェネリック型パラメーターは反変です。 反変型パラメーターは、メソッド シグネチャのパラメーター型として使用できます。

Covariant 1

ジェネリック型パラメーターは共変です。 共変型パラメーターは、メソッドの結果型、読み取り専用フィールドの型、宣言された基本型、または実装されたインターフェイスとして使用できます。

DefaultConstructorConstraint 16

型は、パラメーターなしのコンストラクターがある場合にのみ、ジェネリック型パラメーターに置き換えることができます。

None 0

特別なフラグはありません。

NotNullableValueTypeConstraint 8

型は、値型であり null 許容でない場合にのみ、ジェネリック型パラメーターに置き換えることができます。

ReferenceTypeConstraint 4

型は、参照型の場合にのみ、ジェネリック型パラメーターに置き換えることができます。

SpecialConstraintMask 28

すべての特殊制約フラグの組み合わせを選択します。 この値は、論理 OR を使用して、DefaultConstructorConstraintReferenceTypeConstraint、および NotNullableValueTypeConstraintのフラグを結合した結果です。

VarianceMask 3

すべての分散フラグの組み合わせを選択します。 この値は、論理 OR を使用して次のフラグを組み合わせた結果です:ContravariantCovariant

次のコード例では、2 つの型パラメーターを持つジェネリック型 Test を定義します。 2 番目の型パラメーターには、基底クラス制約と参照型制約があります。 プログラムを実行すると、Type.GenericParameterAttributes プロパティと 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
 */

注釈

GenericParameterAttributes 列挙体のメンバーは、分散グループと特殊制約グループの 2 つのグループに分けられます。 分散フラグの GenericParameterAttributes 値をテストするには、まず VarianceMask でビットごとの AND 演算を実行します。 結果が None の場合、分散フラグはありません。 同様に、SpecialConstraintMask を使用して制約フラグをテストします。

適用対象

製品 バージョン
.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