내보내기(0) 인쇄
모두 확장
정보
요청한 주제가 아래에 표시됩니다. 그러나 이 주제는 이 라이브러리에 포함되지 않습니다.

ParameterBuilder 클래스

2013-12-13

매개 변수 정보를 만들거나 연결합니다.

System.Object
  System.Reflection.Emit.ParameterBuilder

Namespace:  System.Reflection.Emit
어셈블리:  mscorlib(mscorlib.dll)

public class ParameterBuilder

ParameterBuilder 형식에서는 다음과 같은 멤버를 노출합니다.

  이름설명
Public 속성Attributes이 매개 변수에 대한 특성을 가져옵니다.
Public 속성IsIn입력 매개 변수인지 여부를 나타내는 값을 가져옵니다.
Public 속성IsOptional이 매개 변수가 선택적 요소인지 여부를 나타내는 값을 가져옵니다.
Public 속성IsOut이 매개 변수가 출력 매개 변수인지 여부를 나타내는 값을 가져옵니다.
Public 속성Name이 매개 변수의 이름을 가져옵니다.
Public 속성Position이 매개 변수에 대한 서명 위치를 가져옵니다.
맨 위

  이름설명
Public 메서드Equals(Object)지정한 Object가 현재 Object와 같은지 확인합니다. (Object에서 상속됨)
Protected 메서드Finalize가비지 수집기에서 Object를 회수하기 전에 개체가 리소스를 해제하고 다른 정리 작업을 수행할 수 있게 합니다. (Object에서 상속됨)
Public 메서드GetHashCode특정 형식에 대한 해시 함수 역할을 합니다. (Object에서 상속됨)
Public 메서드GetType현재 인스턴스의 Type을 가져옵니다. (Object에서 상속됨)
Protected 메서드MemberwiseClone현재 Object의 단순 복사본을 만듭니다. (Object에서 상속됨)
Public 메서드SetConstant해당 매개 변수의 기본값을 설정합니다.
Public 메서드SetCustomAttribute(CustomAttributeBuilder)사용자 지정 특성 작성기를 사용하여 사용자 지정 특성을 설정합니다.
Public 메서드SetCustomAttribute(ConstructorInfo, Byte[])지정된 사용자 지정 특성 BLOB를 사용하여 사용자 지정 특성을 설정합니다.
Public 메서드ToString현재 개체를 나타내는 문자열을 반환합니다. (Object에서 상속됨)
맨 위

매개 변수 특성은 메서드 서명과 일치해야 합니다. 매개 변수에 Out 특성을 지정한 경우 해당 메서드의 매개 변수는 ByRef 형식이어야 합니다.

일부 ParameterBuilder 특성의 경우에는 MSIL(Microsoft Intermediate Language)이 런타임에 제대로 작동할 수 있도록 유효한 매개 변수를 제공해야 합니다. 예를 들어 메서드의 매개 변수 1에 ParameterAttributes.Out을 사용하여 ParameterBuilder를 정의하면 메서드의 매개 변수 1은 Type.GetType("System.String")이 아니라 Type.GetType("System.String&")과 같은 참조가 되어야 합니다.

다음 예제에서는 ParameterBuilder를 사용하여 참조로 전달된 매개 변수가 있는 동적 메서드를 만드는 방법을 보여 줍니다.

참고참고:

이 예제를 실행하려면 Windows Phone용 정적 TextBlock 컨트롤이 있는 예제 빌드를 참조하세요.



using System;
using System.Threading;
using System.Reflection;
using System.Reflection.Emit;

class Example
{

   public static Type BuildCustomerDataType()
   {

      AppDomain myDomain = Thread.GetDomain();
      AssemblyName myAsmName = new AssemblyName();
      myAsmName.Name = "MyDynamicAssembly";

      AssemblyBuilder myAsmBuilder = myDomain.DefineDynamicAssembly(myAsmName,
                     AssemblyBuilderAccess.Run);

      ModuleBuilder myModBuilder = myAsmBuilder.DefineDynamicModule("MyMod");

      TypeBuilder myTypeBuilder = myModBuilder.DefineType("CustomerData",
                     TypeAttributes.Public);

      FieldBuilder customerNameBldr = myTypeBuilder.DefineField("customerName",
                        typeof(string),
                        FieldAttributes.Private);
      FieldBuilder acctIDBldr = myTypeBuilder.DefineField("acctID",
                        typeof(string),
                        FieldAttributes.Private);
      FieldBuilder balanceAmtBldr = myTypeBuilder.DefineField("balanceAmt",
                        typeof(double),
                        FieldAttributes.Private);

      ConstructorBuilder myCtorBuilder = myTypeBuilder.DefineConstructor(
                        MethodAttributes.Public,
                        CallingConventions.HasThis,
                        new Type[] { typeof(string),
								     typeof(string),
								     typeof(double) });


      ILGenerator ctorIL = myCtorBuilder.GetILGenerator();

      Type objType = Type.GetType("System.Object");
      ConstructorInfo objCtor = objType.GetConstructor(new Type[] { });

      ctorIL.Emit(OpCodes.Ldarg_0);
      ctorIL.Emit(OpCodes.Call, objCtor);

      ctorIL.Emit(OpCodes.Ldarg_0);
      ctorIL.Emit(OpCodes.Ldarg_1);
      ctorIL.Emit(OpCodes.Stfld, customerNameBldr);

      ctorIL.Emit(OpCodes.Ldarg_0);
      ctorIL.Emit(OpCodes.Ldarg_2);
      ctorIL.Emit(OpCodes.Stfld, acctIDBldr);

      ctorIL.Emit(OpCodes.Ldarg_0);
      ctorIL.Emit(OpCodes.Ldarg_3);
      ctorIL.Emit(OpCodes.Stfld, balanceAmtBldr);

      ctorIL.Emit(OpCodes.Ret);

      // This method will take an amount from a static pool and add it to the balance.

      // Note that we are passing the first parameter, fundsPool, by reference. Therefore,
      // we need to inform the MethodBuilder to expect a ref, by declaring the first
      // parameter's type to be System.Double& (a reference to a double).

      MethodBuilder myMthdBuilder = myTypeBuilder.DefineMethod("AddFundsFromPool",
                     MethodAttributes.Public,
                     typeof(double),
                     new Type[] { Type.GetType("System.Double&"),
							     typeof(double) });

      ParameterBuilder poolRefBuilder = myMthdBuilder.DefineParameter(1,
                     ParameterAttributes.Out,
                     "fundsPool");

      ParameterBuilder amountFromPoolBuilder = myMthdBuilder.DefineParameter(2,
                     ParameterAttributes.In,
                          "amountFromPool");

      ILGenerator mthdIL = myMthdBuilder.GetILGenerator();

      mthdIL.Emit(OpCodes.Ldarg_1);
      mthdIL.Emit(OpCodes.Ldarg_1);
      mthdIL.Emit(OpCodes.Ldind_R8);
      mthdIL.Emit(OpCodes.Ldarg_2);
      mthdIL.Emit(OpCodes.Sub);

      mthdIL.Emit(OpCodes.Stind_R8);

      mthdIL.Emit(OpCodes.Ldarg_0);
      mthdIL.Emit(OpCodes.Ldarg_0);
      mthdIL.Emit(OpCodes.Ldfld, balanceAmtBldr);
      mthdIL.Emit(OpCodes.Ldarg_2);
      mthdIL.Emit(OpCodes.Add);

      mthdIL.Emit(OpCodes.Stfld, balanceAmtBldr);

      mthdIL.Emit(OpCodes.Ldarg_0);
      mthdIL.Emit(OpCodes.Ldfld, balanceAmtBldr);
      mthdIL.Emit(OpCodes.Ret);

      return myTypeBuilder.CreateType();

   }

   public static void Demo(System.Windows.Controls.TextBlock outputBlock)
   {
      Type custType = null;
      object custObj = null;

      Type[] custArgTypes = new Type[] { typeof(string), typeof(string), typeof(double) };

      // Call the method to build our dynamic class.

      custType = BuildCustomerDataType();

      outputBlock.Text += "---" + "\n";

      ConstructorInfo myCustCtor = custType.GetConstructor(custArgTypes);
      double initialBalance = 100.00;
      custObj = myCustCtor.Invoke(new object[] { "Joe Consumer", 
						   "5678-XYZ", 
					  	   initialBalance });

      MemberInfo[] myMemberInfo = custType.GetMember("AddFundsFromPool");


      double thePool = 1000.00;
      outputBlock.Text += String.Format("The pool is currently ${0}", thePool) + "\n";
      outputBlock.Text += String.Format("The original balance of the account instance is ${0}",
                        initialBalance) + "\n";

      double amountFromPool = 50.00;
      outputBlock.Text += String.Format("The amount to be subtracted from the pool and added " +
              "to the account is ${0}", amountFromPool) + "\n";

      outputBlock.Text += "---" + "\n";
      outputBlock.Text += String.Format("Calling {0} ...", myMemberInfo[0].ToString()) + "\n";
      outputBlock.Text += "---" + "\n";

      object[] passMe = new object[] { thePool, amountFromPool };
      outputBlock.Text += String.Format("The new balance in the account instance is ${0}",
                  custType.InvokeMember("AddFundsFromPool",
                  BindingFlags.InvokeMethod,
                  null, custObj, passMe)) + "\n";
      thePool = (double)passMe[0];
      outputBlock.Text += String.Format("The new amount in the pool is ${0}", thePool) + "\n";

   }

}



Windows Phone OS

지원되는 버전: 8.0, 7.1

Windows Phone

이 형식의 모든 공용 static(Visual Basic의 경우 Shared) 멤버는 스레드로부터 안전합니다. 모든 인스턴스 멤버는 스레드로부터 안전하지 않을 수 있습니다.

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

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