Module.ResolveMethod 메서드

정의

메타데이터 토큰으로 식별되는 메서드를 반환합니다.

오버로드

ResolveMethod(Int32, Type[], Type[])

지정된 제네릭 형식 매개 변수로 정의되는 컨텍스트에서 지정된 메타데이터 토큰으로 식별되는 메서드 또는 생성자를 반환합니다.

ResolveMethod(Int32)

지정된 메타데이터 토큰으로 식별되는 메서드나 생성자를 반환합니다.

ResolveMethod(Int32, Type[], Type[])

Source:
Module.cs
Source:
Module.cs
Source:
Module.cs

지정된 제네릭 형식 매개 변수로 정의되는 컨텍스트에서 지정된 메타데이터 토큰으로 식별되는 메서드 또는 생성자를 반환합니다.

public virtual System.Reflection.MethodBase? ResolveMethod (int metadataToken, Type[]? genericTypeArguments, Type[]? genericMethodArguments);
public virtual System.Reflection.MethodBase ResolveMethod (int metadataToken, Type[] genericTypeArguments, Type[] genericMethodArguments);
public System.Reflection.MethodBase ResolveMethod (int metadataToken, Type[] genericTypeArguments, Type[] genericMethodArguments);

매개 변수

metadataToken
Int32

모듈의 메서드나 생성자를 식별하는 메타데이터 토큰입니다.

genericTypeArguments
Type[]

해당 토큰이 범위 내에 있는 형식의 제네릭 형식 인수를 나타내는 Type 개체의 배열이거나, 형식이 제네릭이 아닌 경우에는 null입니다.

genericMethodArguments
Type[]

해당 토큰이 범위 내에 있는 메서드의 제네릭 형식 인수를 나타내는 Type 개체의 배열이거나, 메서드가 제네릭이 아닌 경우에는 null입니다.

반환

지정된 메타데이터 토큰으로 식별되는 메서드를 나타내는 MethodBase 개체입니다.

예외

metadataToken이 현재 모듈의 범위에 있는 메서드나 생성자의 토큰이 아닌 경우

또는

metadataTokenMethodSpec(제네릭 형식의 형식 매개 변수) 또는 var(제네릭 메서드의 형식 매개 변수) 요소 형식이 포함된 시그니처를 사용하는 mvar이고, genericTypeArgumentsgenericMethodArguments 중 하나 또는 둘 다에 대해 필요한 제네릭 형식 인수를 제공하지 않은 경우

metadataToken이 현재 모듈의 범위에 있는 유효한 토큰이 아닌 경우

예제

다음 예제에서는 메서드의 ResolveMethod 두 오버로드를 사용하여 제네릭 컨텍스트와 제네릭이 아닌 컨텍스트의 호출 사이트에서 메타데이터 토큰을 resolve 방법을 보여 줍니다.

코드 예제에서는 두 개의 제네릭 형식 및 G2<Tg2>를 정의하며 각 형식 G1<Tg1> 에는 제네릭 메서드가 있습니다. G1<Tg1> 에는 매개 변수에 형식 매개 변수 Tg1 를 사용하는 제네릭이 아닌 메서드도 있습니다. 형식 G2<Tg2> 의 제네릭 메서드 GM2<Tgm2> 에는 다음과 같은 여러 메서드 호출이 포함됩니다.

  • 사례 1: 및 GM2<Tgm2>G2<Tg2> 형식 매개 변수를 형식 인수로 사용하여 제네릭 메서드 GM1<Tgm1> 가 호출됩니다. 즉, 호출된 메서드의 매개 변수 형식은 에 대한 G2<Tg2>형식 정의에서 닫힌 제네릭 형식을 생성하는 데 사용되는 형식에 따라 달라집니다.

  • 사례 2: 제네릭이 아닌 메서드 M1 가 호출됩니다. 이 메서드의 매개 변수는 정의 형식 G1<Tg1>의 형식 매개 변수를 사용합니다. 이 매개 변수는 이 경우 바깥쪽 형식 G2<Tg2>의 형식 매개 변수 로 대체됩니다.

  • 사례 3: 제네릭 메서드가 각각 제네릭 형식 및 제네릭 메서드 GM1<Tgm1> 의 형식 인수에 대해 및 Object 를 지정하여 Int32 호출됩니다. 이 메서드 호출은 바깥쪽 형식 또는 메서드의 형식 매개 변수에 의존하지 않습니다.

  • 사례 4: 클래스의 제네릭이 아닌 메서드 M1Example 호출됩니다. 이 메서드 호출은 바깥쪽 형식 또는 메서드의 형식 매개 변수에 의존하지 않습니다.

또한 이 예제에서는 제네릭 Example 이 아닌 클래스를 정의합니다. 이 클래스에는 제네릭 메서드 M 를 호출하는 메서드가 있습니다.

  • 사례 5: 제네릭 메서드가 각각 제네릭 형식 및 제네릭 메서드 GM1<Tgm1> 의 형식 인수에 대해 및 Object 를 지정하여 Int32 호출됩니다. 이 메서드의 컨텍스트에는 바깥쪽 제네릭 형식 또는 제네릭 메서드가 없습니다.

각 사례에 대해 예제에서는 먼저 호출된 메서드를 나타내는 를 생성 MethodInfo 한 다음 및 메서드를 사용하여 메서드 오버로드를 사용하여 Type.GetGenericArgumentsResolveMethod(Int32, Type[], Type[]) 토큰을 확인하여 및 MethodInfo.GetGenericArgumentsgenericMethodArguments 매개 변수에 genericTypeArguments 대한 값을 가져옵니다. 이 기술은 메서드가 제네릭이 아닌 컨텍스트에 대해 반환 Type.EmptyTypes 하기 때문에 모든 경우에 작동합니다. 이 예제에서는 확인된 MethodInfo 를 생성된 MethodInfo와 비교합니다.

그런 다음, 메서드 오버로드를 사용하여 토큰을 ResolveMethod(Int32) resolve 합니다. 이는 메서드 호출이 제네릭 컨텍스트에 의존하지 않으므로 3, 4 및 5의 경우 작동합니다. 1과 2의 경우 토큰을 resolve 정보가 부족하여 예외가 throw됩니다.

메타데이터 토큰 값은 열거형으로 하드 코딩됩니다. 이 코드 예제를 변경하면 토큰 값이 변경될 수 있습니다. 새 토큰 값을 확인하려면 코드를 컴파일하고 /TOKENS 옵션과 함께 Ildasm.exe 사용하여 어셈블리를 검사합니다. 토큰은 호출 지점에서 찾을 수 있습니다. 새 값을 열거형에 삽입하고 예제를 다시 컴파일합니다.

using System;
using System.Reflection;

namespace ResolveMethodExample
{
    // Metadata tokens for the MethodRefs that are to be resolved.
    // If you change this program, some or all of these metadata tokens might
    // change. The new token values can be discovered by compiling the example
    // and examining the assembly with Ildasm.exe, using the /TOKENS option.
    // Recompile the program after correcting the token values.
    enum Tokens
    {
        Case1 = 0x2b000001,
        Case2 = 0x0A000006,
        Case3 = 0x2b000002,
        Case4 = 0x06000006,
        Case5 = 0x2b000002
    }

    class G1<Tg1>
    {
        public void GM1<Tgm1> (Tg1 param1, Tgm1 param2) {}
        public void M1(Tg1 param) {}
    }

    class G2<Tg2>
    {
        public void GM2<Tgm2> (Tg2 param1, Tgm2 param2)
        {
            // Case 1: A generic method call that depends on its generic
            // context, because it uses the type parameters of the enclosing
            // generic type G2 and the enclosing generic method GM2. The token
            // for the MethodSpec is Tokens.Case1.
            G1<Tg2> g = new G1<Tg2>();
            g.GM1<Tgm2>(param1, param2);

            // Case 2: A non-generic method call that depends on its generic
            // context, because it uses the type parameter of the enclosing
            // generic type G2. The token for the MemberRef is Tokens.Case2.
            g.M1(param1);

            // Case 3: A generic method call that does not depend on its generic
            // context, because it does not use type parameters of the enclosing
            // generic type or method. The token for the MethodSpec is Tokens.Case3.
            G1<int> gi = new G1<int>();
            gi.GM1<object>(42, new Object());

            // Case 4: A non-generic method call that does not depend on its
            // generic context, because it does not use the type parameters of the
            // enclosing generic type or method. The token for the MethodDef is
            // Tokens.Case4.
            Example e = new Example();
            e.M();
        }
    }

    class Example
    {
        public void M()
        {
            G1<int> g = new G1<int>();
            // Case 5: A generic method call that does not have any generic
            // context. The token for the MethodSpec is Tokens.Case5.
            g.GM1<object>(42, new Object());
        }

        static void Main ()
        {
            Module mod = typeof(Example).Assembly.ManifestModule;
            MethodInfo miResolved2 = null;

            // Case 1: A generic method call that is dependent on its generic context.
            //
            // Create and display a MethodInfo representing the MethodSpec of the
            // generic method g.GM1<Tgm2>() that is called in G2<Tg2>.GM2<Tgm2>().
            Type t = typeof(G1<>).MakeGenericType(typeof(G2<>).GetGenericArguments());
            MethodInfo mi = typeof(G2<>).GetMethod("GM2");
            MethodInfo miTest = t.GetMethod("GM1").MakeGenericMethod(mi.GetGenericArguments());
            Console.WriteLine("\nCase 1:\n{0}", miTest);

            // Resolve the MethodSpec token for method G1<Tg2>.GM1<Tgm2>(), which
            // is called in method G2<Tg2>.GM2<Tgm2>(). The GetGenericArguments method
            // must be used to obtain the context for resolving the method.
            MethodInfo miResolved = (MethodInfo) mod.ResolveMethod(
                (int)Tokens.Case1,
                typeof(G2<>).GetGenericArguments(),
                typeof(G2<>).GetMethod("GM2").GetGenericArguments());
            Console.WriteLine(miResolved);
            Console.WriteLine("Is the resolved method the same? {0}", miResolved == miTest);

            // The overload that doesn't specify generic context throws an exception
            // because there is insufficient context to resolve the token.
            try
            {
                miResolved2 = (MethodInfo) mod.ResolveMethod((int)Tokens.Case1);
            }
            catch (Exception ex)
            {
                Console.WriteLine("{0}: {1}", ex.GetType(), ex.Message);
            }

            // Case 2: A non-generic method call that is dependent on its generic context.
            //
            // Create and display a MethodInfo representing the MemberRef of the
            // non-generic method g.M1() that is called in G2<Tg2>.GM2<Tgm2>().
            t = typeof(G1<>).MakeGenericType(typeof(G2<>).GetGenericArguments());
            miTest = t.GetMethod("M1");
            Console.WriteLine("\nCase 2:\n{0}", miTest);

            // Resolve the MemberRef token for method G1<Tg2>.M1(), which is
            // called in method G2<Tg2>.GM2<Tgm2>(). The GetGenericArguments method
            // must be used to obtain the context for resolving the method, because
            // the method parameter comes from the generic type G1, and the type
            // argument, Tg2, comes from the generic type that encloses the call.
            // There is no enclosing generic method, so the value Type.EmptyTypes
            // could be passed for the genericMethodArguments parameter.
            miResolved = (MethodInfo) mod.ResolveMethod(
                (int)Tokens.Case2,
                typeof(G2<>).GetGenericArguments(),
                typeof(G2<>).GetMethod("GM2").GetGenericArguments());
            Console.WriteLine(miResolved);
            Console.WriteLine("Is the resolved method the same? {0}", miResolved == miTest);

            // The overload that doesn't specify generic context throws an exception
            // because there is insufficient context to resolve the token.
            try
            {
                miResolved2 = (MethodInfo) mod.ResolveMethod((int)Tokens.Case2);
            }
            catch (Exception ex)
            {
                Console.WriteLine("{0}: {1}", ex.GetType(), ex.Message);
            }

            // Case 3: A generic method call that is independent of its generic context.
            //
            // Create and display a MethodInfo representing the MethodSpec of the
            // generic method gi.GM1<object>() that is called in G2<Tg2>.GM2<Tgm2>().
            mi = typeof(G1<int>).GetMethod("GM1");
            miTest = mi.MakeGenericMethod(new Type[] { typeof(object) });
            Console.WriteLine("\nCase 3:\n{0}", miTest);

            // Resolve the token for method G1<int>.GM1<object>(), which is called
            // in G2<Tg2>.GM2<Tgm2>(). The GetGenericArguments method is used to
            // obtain the context for resolving the method, but the method call in
            // this case does not use type parameters of the enclosing type or
            // method, so Type.EmptyTypes could be used for both arguments.
            miResolved = (MethodInfo) mod.ResolveMethod(
                (int)Tokens.Case3,
                typeof(G2<>).GetGenericArguments(),
                typeof(G2<>).GetMethod("GM2").GetGenericArguments());
            Console.WriteLine(miResolved);
            Console.WriteLine("Is the resolved method the same? {0}", miResolved == miTest);

            // The method call in this case does not depend on the enclosing generic
            // context, so the token can also be resolved by the simpler overload.
            miResolved2 = (MethodInfo) mod.ResolveMethod((int)Tokens.Case3);

            // Case 4: A non-generic method call that is independent of its generic context.
            //
            // Create and display a MethodInfo representing the MethodDef of the
            // method e.M() that is called in G2<Tg2>.GM2<Tgm2>().
            miTest = typeof(Example).GetMethod("M");
            Console.WriteLine("\nCase 4:\n{0}", miTest);

            // Resolve the token for method Example.M(), which is called in
            // G2<Tg2>.GM2<Tgm2>(). The GetGenericArguments method is used to
            // obtain the context for resolving the method, but the non-generic
            // method call does not use type parameters of the enclosing type or
            // method, so Type.EmptyTypes could be used for both arguments.
            miResolved = (MethodInfo) mod.ResolveMethod(
                (int)Tokens.Case4,
                typeof(G2<>).GetGenericArguments(),
                typeof(G2<>).GetMethod("GM2").GetGenericArguments());
            Console.WriteLine(miResolved);
            Console.WriteLine("Is the resolved method the same? {0}", miResolved == miTest);

            // The method call in this case does not depend on any enclosing generic
            // context, so the token can also be resolved by the simpler overload.
            miResolved2 = (MethodInfo) mod.ResolveMethod((int)Tokens.Case4);

            // Case 5: Generic method call in a non-generic context.
            //
            // Create and display a MethodInfo representing the MethodRef of the
            // closed generic method g.GM1<object>() that is called in Example.M().
            mi = typeof(G1<int>).GetMethod("GM1");
            miTest = mi.MakeGenericMethod(new Type[] { typeof(object) });
            Console.WriteLine("\nCase 5:\n{0}", miTest);

            // Resolve the token for method G1<int>.GM1<object>(), which is called
            // in method Example.M(). The GetGenericArguments method is used to
            // obtain the context for resolving the method, but the enclosing type
            // and method are not generic, so Type.EmptyTypes could be used for
            // both arguments.
            miResolved = (MethodInfo) mod.ResolveMethod(
                (int)Tokens.Case5,
                typeof(Example).GetGenericArguments(),
                typeof(Example).GetMethod("M").GetGenericArguments());
            Console.WriteLine(miResolved);
            Console.WriteLine("Is the resolved method the same? {0}", miResolved == miTest);

            // The method call in this case does not depend on any enclosing generic
            // context, so the token can also be resolved by the simpler overload.
            miResolved2 = (MethodInfo) mod.ResolveMethod((int)Tokens.Case5);
        }
    }
}
/* This example produces the following output:

Case 1:
Void GM1[Tgm2](Tg2, Tgm2)
Void GM1[Tgm2](Tg2, Tgm2)
Is the resolved method the same? True
System.ArgumentException: A BadImageFormatException has been thrown while parsing the signature. This is likely due to lack of a generic context. Ensure genericTypeArguments and genericMethodArguments are provided and contain enough context.

Case 2:
Void M1(Tg2)
Void M1(Tg2)
Is the resolved method the same? True
System.ArgumentException: A BadImageFormatException has been thrown while parsing the signature. This is likely due to lack of a generic context. Ensure genericTypeArguments and genericMethodArguments are provided and contain enough context.

Case 3:
Void GM1[Object](Int32, System.Object)
Void GM1[Object](Int32, System.Object)
Is the resolved method the same? True

Case 4:
Void M()
Void M()
Is the resolved method the same? True

Case 5:
Void GM1[Object](Int32, System.Object)
Void GM1[Object](Int32, System.Object)
Is the resolved method the same? True
 */

설명

Type.GetGenericArguments 에 대한 제네릭 형식 metadataToken 인수의 배열을 가져오려면 가 scope 형식에서 메서드를 genericTypeArguments사용합니다. MethodInfo.GetGenericArguments 에 대한 제네릭 형식 인수 배열을 가져오려면 가 scope 메서드에서 메서드 metadataTokengenericMethodArguments사용합니다. 필요하지 않은 경우에도 항상 이러한 인수를 제공하는 것이 안전합니다.

참고

메타데이터 토큰에 대한 정보는 CLI(공용 언어 인프라) 설명서, 특히 "파티션 II: 메타데이터 정의 및 의미 체계"에서 찾을 수 있습니다. 자세한 내용은 ECMA 335 CLI(공용 언어 인프라)를 참조하세요.

적용 대상

.NET 9 및 기타 버전
제품 버전
.NET 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 2.0, 2.1

ResolveMethod(Int32)

Source:
Module.cs
Source:
Module.cs
Source:
Module.cs

지정된 메타데이터 토큰으로 식별되는 메서드나 생성자를 반환합니다.

public System.Reflection.MethodBase? ResolveMethod (int metadataToken);
public System.Reflection.MethodBase ResolveMethod (int metadataToken);

매개 변수

metadataToken
Int32

모듈의 메서드나 생성자를 식별하는 메타데이터 토큰입니다.

반환

지정된 메타데이터 토큰으로 식별되는 메서드나 생성자를 나타내는 MethodBase 개체입니다.

예외

metadataToken이 현재 모듈의 범위에 있는 메서드나 생성자의 토큰이 아닌 경우

또는

metadataTokenMethodSpec(제네릭 형식의 형식 매개 변수) 또는 var(제네릭 메서드의 형식 매개 변수) 요소 형식이 포함된 시그니처를 사용하는 mvar인 경우

metadataToken이 현재 모듈의 범위에 있는 유효한 토큰이 아닌 경우

예제

다음 예제에서는 메서드의 ResolveMethod 두 오버로드를 사용하여 제네릭 컨텍스트와 제네릭이 아닌 컨텍스트의 호출 사이트에서 메타데이터 토큰을 resolve 방법을 보여 줍니다.

코드 예제에서는 두 개의 제네릭 형식 및 (G1(Of Tg1)G2(Of Tg2)G2<Tg2> Visual Basic에서)를 정의하며 각 형식 G1<Tg1> 에는 제네릭 메서드가 있습니다. G1<Tg1> 에는 매개 변수에 형식 매개 변수 Tg1 를 사용하는 제네릭이 아닌 메서드도 있습니다. 형식 G2<Tg2> 의 제네릭 메서드 GM2<Tgm2> 에는 다음과 같은 여러 메서드 호출이 포함됩니다.

  • 사례 1: 및 GM2<Tgm2>G2<Tg2> 형식 매개 변수를 형식 인수로 사용하여 제네릭 메서드 GM1<Tgm1> 가 호출됩니다. 즉, 호출된 메서드의 매개 변수 형식은 에 대한 G2<Tg2>형식 정의에서 닫힌 제네릭 형식을 생성하는 데 사용되는 형식에 따라 달라집니다.

  • 사례 2: 제네릭이 아닌 메서드 M1 가 호출됩니다. 이 메서드의 매개 변수는 정의 형식 G1<Tg1>의 형식 매개 변수를 사용합니다. 이 매개 변수는 이 경우 바깥쪽 형식 G2<Tg2>의 형식 매개 변수 로 대체됩니다.

  • 사례 3: 제네릭 메서드가 각각 제네릭 형식 및 제네릭 메서드 GM1<Tgm1> 의 형식 인수에 대해 및 Object 를 지정하여 Int32 호출됩니다. 이 메서드 호출은 바깥쪽 형식 또는 메서드의 형식 매개 변수에 의존하지 않습니다.

  • 사례 4: 클래스의 제네릭이 아닌 메서드 M1Example 호출됩니다. 이 메서드 호출은 바깥쪽 형식 또는 메서드의 형식 매개 변수에 의존하지 않습니다.

또한 이 예제에서는 제네릭 Example 이 아닌 클래스를 정의합니다. 이 클래스에는 제네릭 메서드 M 를 호출하는 메서드가 있습니다.

  • 사례 5: 제네릭 메서드가 각각 제네릭 형식 및 제네릭 메서드 GM1 의 형식 인수에 대해 및 Object 를 지정하여 Int32 호출됩니다. 이 메서드의 컨텍스트에는 바깥쪽 제네릭 형식 또는 제네릭 메서드가 없습니다.

각 사례에 대해 예제에서는 먼저 호출된 메서드를 나타내는 를 생성 MethodInfo 한 다음 및 메서드를 사용하여 메서드 오버로드를 사용하여 Type.GetGenericArgumentsResolveMethod(Int32, Type[], Type[]) 토큰을 확인하여 및 MethodInfo.GetGenericArgumentsgenericMethodArguments 매개 변수에 genericTypeArguments 대한 값을 가져옵니다. 이 기술은 메서드가 제네릭이 아닌 컨텍스트에 대해 반환 Type.EmptyTypes 하기 때문에 모든 경우에 작동합니다. 이 예제에서는 확인된 MethodInfo 를 생성된 MethodInfo와 비교합니다.

그런 다음, 메서드 오버로드를 사용하여 토큰을 ResolveMethod(Int32) resolve 합니다. 이는 메서드 호출이 제네릭 컨텍스트에 의존하지 않으므로 3, 4 및 5의 경우 작동합니다. 1과 2의 경우 토큰을 resolve 정보가 부족하여 예외가 throw됩니다.

메타데이터 토큰 값은 열거형으로 하드 코딩됩니다. 이 코드 예제를 변경하면 토큰 값이 변경될 수 있습니다. 새 토큰 값을 확인하려면 코드를 컴파일하고 /TOKENS 옵션과 함께 Ildasm.exe 사용하여 어셈블리를 검사합니다. 토큰은 호출 지점에서 찾을 수 있습니다. 새 값을 열거형에 삽입하고 예제를 다시 컴파일합니다.

using System;
using System.Reflection;

namespace ResolveMethodExample
{
    // Metadata tokens for the MethodRefs that are to be resolved.
    // If you change this program, some or all of these metadata tokens might
    // change. The new token values can be discovered by compiling the example
    // and examining the assembly with Ildasm.exe, using the /TOKENS option.
    // Recompile the program after correcting the token values.
    enum Tokens
    {
        Case1 = 0x2b000001,
        Case2 = 0x0A000006,
        Case3 = 0x2b000002,
        Case4 = 0x06000006,
        Case5 = 0x2b000002
    }

    class G1<Tg1>
    {
        public void GM1<Tgm1> (Tg1 param1, Tgm1 param2) {}
        public void M1(Tg1 param) {}
    }

    class G2<Tg2>
    {
        public void GM2<Tgm2> (Tg2 param1, Tgm2 param2)
        {
            // Case 1: A generic method call that depends on its generic
            // context, because it uses the type parameters of the enclosing
            // generic type G2 and the enclosing generic method GM2. The token
            // for the MethodSpec is Tokens.Case1.
            G1<Tg2> g = new G1<Tg2>();
            g.GM1<Tgm2>(param1, param2);

            // Case 2: A non-generic method call that depends on its generic
            // context, because it uses the type parameter of the enclosing
            // generic type G2. The token for the MemberRef is Tokens.Case2.
            g.M1(param1);

            // Case 3: A generic method call that does not depend on its generic
            // context, because it does not use type parameters of the enclosing
            // generic type or method. The token for the MethodSpec is Tokens.Case3.
            G1<int> gi = new G1<int>();
            gi.GM1<object>(42, new Object());

            // Case 4: A non-generic method call that does not depend on its
            // generic context, because it does not use the type parameters of the
            // enclosing generic type or method. The token for the MethodDef is
            // Tokens.Case4.
            Example e = new Example();
            e.M();
        }
    }

    class Example
    {
        public void M()
        {
            G1<int> g = new G1<int>();
            // Case 5: A generic method call that does not have any generic
            // context. The token for the MethodSpec is Tokens.Case5.
            g.GM1<object>(42, new Object());
        }

        static void Main ()
        {
            Module mod = typeof(Example).Assembly.ManifestModule;
            MethodInfo miResolved2 = null;

            // Case 1: A generic method call that is dependent on its generic context.
            //
            // Create and display a MethodInfo representing the MethodSpec of the
            // generic method g.GM1<Tgm2>() that is called in G2<Tg2>.GM2<Tgm2>().
            Type t = typeof(G1<>).MakeGenericType(typeof(G2<>).GetGenericArguments());
            MethodInfo mi = typeof(G2<>).GetMethod("GM2");
            MethodInfo miTest = t.GetMethod("GM1").MakeGenericMethod(mi.GetGenericArguments());
            Console.WriteLine("\nCase 1:\n{0}", miTest);

            // Resolve the MethodSpec token for method G1<Tg2>.GM1<Tgm2>(), which
            // is called in method G2<Tg2>.GM2<Tgm2>(). The GetGenericArguments method
            // must be used to obtain the context for resolving the method.
            MethodInfo miResolved = (MethodInfo) mod.ResolveMethod(
                (int)Tokens.Case1,
                typeof(G2<>).GetGenericArguments(),
                typeof(G2<>).GetMethod("GM2").GetGenericArguments());
            Console.WriteLine(miResolved);
            Console.WriteLine("Is the resolved method the same? {0}", miResolved == miTest);

            // The overload that doesn't specify generic context throws an exception
            // because there is insufficient context to resolve the token.
            try
            {
                miResolved2 = (MethodInfo) mod.ResolveMethod((int)Tokens.Case1);
            }
            catch (Exception ex)
            {
                Console.WriteLine("{0}: {1}", ex.GetType(), ex.Message);
            }

            // Case 2: A non-generic method call that is dependent on its generic context.
            //
            // Create and display a MethodInfo representing the MemberRef of the
            // non-generic method g.M1() that is called in G2<Tg2>.GM2<Tgm2>().
            t = typeof(G1<>).MakeGenericType(typeof(G2<>).GetGenericArguments());
            miTest = t.GetMethod("M1");
            Console.WriteLine("\nCase 2:\n{0}", miTest);

            // Resolve the MemberRef token for method G1<Tg2>.M1(), which is
            // called in method G2<Tg2>.GM2<Tgm2>(). The GetGenericArguments method
            // must be used to obtain the context for resolving the method, because
            // the method parameter comes from the generic type G1, and the type
            // argument, Tg2, comes from the generic type that encloses the call.
            // There is no enclosing generic method, so the value Type.EmptyTypes
            // could be passed for the genericMethodArguments parameter.
            miResolved = (MethodInfo) mod.ResolveMethod(
                (int)Tokens.Case2,
                typeof(G2<>).GetGenericArguments(),
                typeof(G2<>).GetMethod("GM2").GetGenericArguments());
            Console.WriteLine(miResolved);
            Console.WriteLine("Is the resolved method the same? {0}", miResolved == miTest);

            // The overload that doesn't specify generic context throws an exception
            // because there is insufficient context to resolve the token.
            try
            {
                miResolved2 = (MethodInfo) mod.ResolveMethod((int)Tokens.Case2);
            }
            catch (Exception ex)
            {
                Console.WriteLine("{0}: {1}", ex.GetType(), ex.Message);
            }

            // Case 3: A generic method call that is independent of its generic context.
            //
            // Create and display a MethodInfo representing the MethodSpec of the
            // generic method gi.GM1<object>() that is called in G2<Tg2>.GM2<Tgm2>().
            mi = typeof(G1<int>).GetMethod("GM1");
            miTest = mi.MakeGenericMethod(new Type[] { typeof(object) });
            Console.WriteLine("\nCase 3:\n{0}", miTest);

            // Resolve the token for method G1<int>.GM1<object>(), which is called
            // in G2<Tg2>.GM2<Tgm2>(). The GetGenericArguments method is used to
            // obtain the context for resolving the method, but the method call in
            // this case does not use type parameters of the enclosing type or
            // method, so Type.EmptyTypes could be used for both arguments.
            miResolved = (MethodInfo) mod.ResolveMethod(
                (int)Tokens.Case3,
                typeof(G2<>).GetGenericArguments(),
                typeof(G2<>).GetMethod("GM2").GetGenericArguments());
            Console.WriteLine(miResolved);
            Console.WriteLine("Is the resolved method the same? {0}", miResolved == miTest);

            // The method call in this case does not depend on the enclosing generic
            // context, so the token can also be resolved by the simpler overload.
            miResolved2 = (MethodInfo) mod.ResolveMethod((int)Tokens.Case3);

            // Case 4: A non-generic method call that is independent of its generic context.
            //
            // Create and display a MethodInfo representing the MethodDef of the
            // method e.M() that is called in G2<Tg2>.GM2<Tgm2>().
            miTest = typeof(Example).GetMethod("M");
            Console.WriteLine("\nCase 4:\n{0}", miTest);

            // Resolve the token for method Example.M(), which is called in
            // G2<Tg2>.GM2<Tgm2>(). The GetGenericArguments method is used to
            // obtain the context for resolving the method, but the non-generic
            // method call does not use type parameters of the enclosing type or
            // method, so Type.EmptyTypes could be used for both arguments.
            miResolved = (MethodInfo) mod.ResolveMethod(
                (int)Tokens.Case4,
                typeof(G2<>).GetGenericArguments(),
                typeof(G2<>).GetMethod("GM2").GetGenericArguments());
            Console.WriteLine(miResolved);
            Console.WriteLine("Is the resolved method the same? {0}", miResolved == miTest);

            // The method call in this case does not depend on any enclosing generic
            // context, so the token can also be resolved by the simpler overload.
            miResolved2 = (MethodInfo) mod.ResolveMethod((int)Tokens.Case4);

            // Case 5: Generic method call in a non-generic context.
            //
            // Create and display a MethodInfo representing the MethodRef of the
            // closed generic method g.GM1<object>() that is called in Example.M().
            mi = typeof(G1<int>).GetMethod("GM1");
            miTest = mi.MakeGenericMethod(new Type[] { typeof(object) });
            Console.WriteLine("\nCase 5:\n{0}", miTest);

            // Resolve the token for method G1<int>.GM1<object>(), which is called
            // in method Example.M(). The GetGenericArguments method is used to
            // obtain the context for resolving the method, but the enclosing type
            // and method are not generic, so Type.EmptyTypes could be used for
            // both arguments.
            miResolved = (MethodInfo) mod.ResolveMethod(
                (int)Tokens.Case5,
                typeof(Example).GetGenericArguments(),
                typeof(Example).GetMethod("M").GetGenericArguments());
            Console.WriteLine(miResolved);
            Console.WriteLine("Is the resolved method the same? {0}", miResolved == miTest);

            // The method call in this case does not depend on any enclosing generic
            // context, so the token can also be resolved by the simpler overload.
            miResolved2 = (MethodInfo) mod.ResolveMethod((int)Tokens.Case5);
        }
    }
}
/* This example produces the following output:

Case 1:
Void GM1[Tgm2](Tg2, Tgm2)
Void GM1[Tgm2](Tg2, Tgm2)
Is the resolved method the same? True
System.ArgumentException: A BadImageFormatException has been thrown while parsing the signature. This is likely due to lack of a generic context. Ensure genericTypeArguments and genericMethodArguments are provided and contain enough context.

Case 2:
Void M1(Tg2)
Void M1(Tg2)
Is the resolved method the same? True
System.ArgumentException: A BadImageFormatException has been thrown while parsing the signature. This is likely due to lack of a generic context. Ensure genericTypeArguments and genericMethodArguments are provided and contain enough context.

Case 3:
Void GM1[Object](Int32, System.Object)
Void GM1[Object](Int32, System.Object)
Is the resolved method the same? True

Case 4:
Void M()
Void M()
Is the resolved method the same? True

Case 5:
Void GM1[Object](Int32, System.Object)
Void GM1[Object](Int32, System.Object)
Is the resolved method the same? True
 */

설명

서명에 요소 형식 ELEMENT_TYPE_VAR 또는 ELEMENT_TYPE_MVAR가 포함된 에 대한 MethodSpec 메타데이터 토큰을 resolve 메서드 오버로드를 사용하여 ResolveMethod(Int32, Type[], Type[]) 필요한 컨텍스트를 제공할 수 있습니다. 즉, 제네릭 형식의 제네릭 형식 매개 변수 및/또는 토큰이 포함된 제네릭 메서드에 의존하는 메서드에 대한 메타데이터 토큰을 확인하는 경우 해당 형식 매개 변수를 제공할 수 있는 오버로드를 사용해야 합니다.

참고

메타데이터 토큰에 대한 정보는 CLI(공용 언어 인프라) 설명서, 특히 "파티션 II: 메타데이터 정의 및 의미 체계"에서 찾을 수 있습니다. 자세한 내용은 ECMA 335 CLI(공용 언어 인프라)를 참조하세요.

적용 대상

.NET 9 및 기타 버전
제품 버전
.NET 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 2.0, 2.1