내보내기(0) 인쇄
모두 확장
확장 최소화
이 문서는 수동으로 번역한 것입니다. 원본 텍스트를 보려면 포인터를 문서의 문장 위로 올리십시오.
번역
원본

GenericParameterAttributes 열거형

제네릭 형식 또는 메서드의 제네릭 형식 매개 변수에 대한 제약 조건을 설명합니다.

이 열거형에는 멤버 값을 비트로 조합할 수 있는 FlagsAttribute 특성이 있습니다.

네임스페이스:  System.Reflection
어셈블리:  mscorlib(mscorlib.dll)

[FlagsAttribute]
public enum GenericParameterAttributes

멤버 이름설명
ms145349.PortableClassLibrary(ko-kr,VS.100).gifNone특수 플래그가 없습니다.
ms145349.PortableClassLibrary(ko-kr,VS.100).gifVarianceMask모든 가변성 플래그의 조합을 선택합니다. 이 값은 ContravariantCovariant 플래그를 논리 OR 연산으로 결합한 결과입니다.
ms145349.PortableClassLibrary(ko-kr,VS.100).gifCovariant제네릭 형식 매개 변수가 공변입니다. 공변 형식 매개 변수는 메서드의 결과 형식, 읽기 전용 필드의 형식, 선언된 기본 형식 또는 구현된 인터페이스로 나타날 수 있습니다.
ms145349.PortableClassLibrary(ko-kr,VS.100).gifContravariant제네릭 형식 매개 변수가 반공변입니다. 반공변 형식 매개 변수는 메서드 시그니처에서 매개 변수 형식으로 나타날 수 있습니다.
ms145349.PortableClassLibrary(ko-kr,VS.100).gifSpecialConstraintMask모든 특수 제약 조건 플래그의 조합을 선택합니다. 이 값은 DefaultConstructorConstraint, ReferenceTypeConstraintNotNullableValueTypeConstraint 플래그를 논리 OR 연산으로 결합한 결과입니다.
ms145349.PortableClassLibrary(ko-kr,VS.100).gifReferenceTypeConstraint제네릭 형식 매개 변수가 참조 형식인 경우에만 제네릭 형식 매개 변수의 형식을 대체할 수 있습니다.
ms145349.PortableClassLibrary(ko-kr,VS.100).gifNotNullableValueTypeConstraint제네릭 형식 매개 변수가 값 형식이고 null을 허용하지 않는 경우에만 제네릭 형식 매개 변수의 형식을 대체할 수 있습니다.
ms145349.PortableClassLibrary(ko-kr,VS.100).gifDefaultConstructorConstraint제네릭 형식 매개 변수에 매개 변수 없는 생성자가 있는 경우에만 제네릭 형식 매개 변수의 형식을 대체할 수 있습니다.

GenericParameterAttributes 열거형의 멤버는 가변성 그룹과 특수 제약 조건 그룹으로 나뉩니다. 가변성 플래그의 GenericParameterAttributes 값을 테스트하려면 먼저 VarianceMask를 사용하여 비트 AND 연산을 수행합니다. 결과가 None이면 가변성 플래그가 없는 것입니다. 마찬가지로, 제약 조건 플래그를 테스트하려면 SpecialConstraintMask를 사용합니다.

다음 코드 예제에서는 두 개의 형식 매개 변수가 있는 제네릭 형식 Test를 정의합니다. 두 번째 형식 매개 변수에는 기본 클래스 제약 조건과 참조 형식 제약 조건이 있습니다. 프로그램이 실행되면 Type.GenericParameterAttributes 속성 및 Type.GetGenericParameterConstraints 메서드를 사용하여 이 제약 조건이 검사됩니다.


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
 */


.NET Framework

4, 3.5, 3.0, 2.0에서 지원

.NET Framework Client Profile

4, 3.5 SP1에서 지원

에서 지원

Windows 7, Windows Vista SP1 이상, Windows XP SP3, Windows XP SP2 x64 버전, Windows Server 2008(Server Core는 지원되지 않음), Windows Server 2008 R2(Server Core는 SP1 이상에서 지원됨), Windows Server 2003 SP2

.NET Framework에서 모든 플랫폼의 전체 버전을 지원하지는 않습니다. 지원되는 버전의 목록을 보려면 .NET Framework 시스템 요구 사항을 참조하십시오.

커뮤니티 추가 항목

추가
Microsoft는 MSDN 웹 사이트에 대한 귀하의 의견을 이해하기 위해 온라인 설문 조사를 진행하고 있습니다. 참여하도록 선택하시면 MSDN 웹 사이트에서 나가실 때 온라인 설문 조사가 표시됩니다.

참여하시겠습니까?
표시:
© 2014 Microsoft