AssemblyBuilder Clase

Definición

Define y representa un ensamblado dinámico.Defines and represents a dynamic assembly.

public ref class AssemblyBuilder sealed : System::Reflection::Assembly
public ref class AssemblyBuilder sealed : System::Reflection::Assembly, System::Runtime::InteropServices::_AssemblyBuilder
public ref class AssemblyBuilder : System::Reflection::Assembly
public sealed class AssemblyBuilder : System.Reflection.Assembly
[System.Runtime.InteropServices.ClassInterface(System.Runtime.InteropServices.ClassInterfaceType.None)]
public sealed class AssemblyBuilder : System.Reflection.Assembly, System.Runtime.InteropServices._AssemblyBuilder
[System.Runtime.InteropServices.ClassInterface(System.Runtime.InteropServices.ClassInterfaceType.None)]
[System.Runtime.InteropServices.ComVisible(true)]
public sealed class AssemblyBuilder : System.Reflection.Assembly, System.Runtime.InteropServices._AssemblyBuilder
public class AssemblyBuilder : System.Reflection.Assembly
type AssemblyBuilder = class
    inherit Assembly
[<System.Runtime.InteropServices.ClassInterface(System.Runtime.InteropServices.ClassInterfaceType.None)>]
type AssemblyBuilder = class
    inherit Assembly
    interface _AssemblyBuilder
[<System.Runtime.InteropServices.ClassInterface(System.Runtime.InteropServices.ClassInterfaceType.None)>]
[<System.Runtime.InteropServices.ComVisible(true)>]
type AssemblyBuilder = class
    inherit Assembly
    interface _AssemblyBuilder
Public NotInheritable Class AssemblyBuilder
Inherits Assembly
Public NotInheritable Class AssemblyBuilder
Inherits Assembly
Implements _AssemblyBuilder
Public Class AssemblyBuilder
Inherits Assembly
Herencia
AssemblyBuilder
Atributos
Implementaciones

Ejemplos

En el ejemplo de código siguiente se muestra cómo definir un ensamblado dinámico con un módulo.The following code example shows how to define a dynamic assembly with one module. El módulo del ensamblado de ejemplo contiene un tipo, MyDynamicType , que tiene un campo privado, una propiedad que obtiene y establece el campo privado, constructores que inicializan el campo privado y un método que multiplica un número proporcionado por el usuario por el valor del campo privado y devuelve el resultado.The module in the example assembly contains one type, MyDynamicType, which has a private field, a property that gets and sets the private field, constructors that initialize the private field, and a method that multiplies a user-supplied number by the private field value and returns the result.

AssemblyBuilderAccess.RunAndSave se especifica cuando se crea el ensamblado.AssemblyBuilderAccess.RunAndSave is specified when the assembly is created. El código de ensamblado se usa inmediatamente y el ensamblado también se guarda en el disco para que se pueda examinar con Ildasm.exe (desensamblador de IL) o usarse en otro programa.The assembly code is used immediately, and the assembly is also saved to disk so that it can be examined with Ildasm.exe (IL Disassembler) or used in another program.

using namespace System;
using namespace System::Reflection;
using namespace System::Reflection::Emit;

void main()
{
    // An assembly consists of one or more modules, each of which
    // contains zero or more types. This code creates a single-module
    // assembly, the most common case. The module contains one type,
    // named "MyDynamicType", that has a private field, a property 
    // that gets and sets the private field, constructors that 
    // initialize the private field, and a method that multiplies 
    // a user-supplied number by the private field value and returns
    // the result. In Visual C++ the type might look like this:
    /*
      public ref class MyDynamicType
      {
      private:
          int m_number;

      public:
          MyDynamicType() : m_number(42) {};
          MyDynamicType(int initNumber) : m_number(initNumber) {};
      
          property int Number
          {
              int get() { return m_number; }
              void set(int value) { m_number = value; }
          }

          int MyMethod(int multiplier)
          {
              return m_number * multiplier;
          }
      };
    */
      
    AssemblyName^ aName = gcnew AssemblyName("DynamicAssemblyExample");
    AssemblyBuilder^ ab = 
        AppDomain::CurrentDomain->DefineDynamicAssembly(
            aName, 
            AssemblyBuilderAccess::RunAndSave);

    // For a single-module assembly, the module name is usually
    // the assembly name plus an extension.
    ModuleBuilder^ mb = 
        ab->DefineDynamicModule(aName->Name, aName->Name + ".dll");
      
    TypeBuilder^ tb = mb->DefineType(
        "MyDynamicType", 
         TypeAttributes::Public);

    // Add a private field of type int (Int32).
    FieldBuilder^ fbNumber = tb->DefineField(
        "m_number", 
        int::typeid, 
        FieldAttributes::Private);

    // Define a constructor that takes an integer argument and 
    // stores it in the private field. 
    array<Type^>^ parameterTypes = { int::typeid };
    ConstructorBuilder^ ctor1 = tb->DefineConstructor(
        MethodAttributes::Public, 
        CallingConventions::Standard, 
        parameterTypes);

    ILGenerator^ ctor1IL = ctor1->GetILGenerator();
    // For a constructor, argument zero is a reference to the new
    // instance. Push it on the stack before calling the base
    // class constructor. Specify the default constructor of the 
    // base class (System::Object) by passing an empty array of 
    // types (Type::EmptyTypes) to GetConstructor.
    ctor1IL->Emit(OpCodes::Ldarg_0);
    ctor1IL->Emit(OpCodes::Call, 
        Object::typeid->GetConstructor(Type::EmptyTypes));
    // Push the instance on the stack before pushing the argument
    // that is to be assigned to the private field m_number.
    ctor1IL->Emit(OpCodes::Ldarg_0);
    ctor1IL->Emit(OpCodes::Ldarg_1);
    ctor1IL->Emit(OpCodes::Stfld, fbNumber);
    ctor1IL->Emit(OpCodes::Ret);

    // Define a default constructor that supplies a default value
    // for the private field. For parameter types, pass the empty
    // array of types or pass nullptr.
    ConstructorBuilder^ ctor0 = tb->DefineConstructor(
        MethodAttributes::Public, 
        CallingConventions::Standard, 
        Type::EmptyTypes);

    ILGenerator^ ctor0IL = ctor0->GetILGenerator();
    ctor0IL->Emit(OpCodes::Ldarg_0);
    ctor0IL->Emit(OpCodes::Call, 
        Object::typeid->GetConstructor(Type::EmptyTypes));
    // For a constructor, argument zero is a reference to the new
    // instance. Push it on the stack before pushing the default
    // value on the stack.
    ctor0IL->Emit(OpCodes::Ldarg_0);
    ctor0IL->Emit(OpCodes::Ldc_I4_S, 42);
    ctor0IL->Emit(OpCodes::Stfld, fbNumber);
    ctor0IL->Emit(OpCodes::Ret);

    // Define a property named Number that gets and sets the private 
    // field.
    //
    // The last argument of DefineProperty is nullptr, because the
    // property has no parameters. (If you don't specify nullptr, you must
    // specify an array of Type objects. For a parameterless property,
    // use the built-in array with no elements: Type::EmptyTypes)
    PropertyBuilder^ pbNumber = tb->DefineProperty(
        "Number", 
        PropertyAttributes::HasDefault, 
        int::typeid, 
        nullptr);
      
    // The property "set" and property "get" methods require a special
    // set of attributes.
    MethodAttributes getSetAttr = MethodAttributes::Public | 
        MethodAttributes::SpecialName | MethodAttributes::HideBySig;

    // Define the "get" accessor method for Number. The method returns
    // an integer and has no arguments. (Note that nullptr could be 
    // used instead of Types::EmptyTypes)
    MethodBuilder^ mbNumberGetAccessor = tb->DefineMethod(
        "get_Number", 
        getSetAttr, 
        int::typeid, 
        Type::EmptyTypes);
      
    ILGenerator^ numberGetIL = mbNumberGetAccessor->GetILGenerator();
    // For an instance property, argument zero is the instance. Load the 
    // instance, then load the private field and return, leaving the
    // field value on the stack.
    numberGetIL->Emit(OpCodes::Ldarg_0);
    numberGetIL->Emit(OpCodes::Ldfld, fbNumber);
    numberGetIL->Emit(OpCodes::Ret);
    
    // Define the "set" accessor method for Number, which has no return
    // type and takes one argument of type int (Int32).
    MethodBuilder^ mbNumberSetAccessor = tb->DefineMethod(
        "set_Number", 
        getSetAttr, 
        nullptr, 
        gcnew array<Type^> { int::typeid });
      
    ILGenerator^ numberSetIL = mbNumberSetAccessor->GetILGenerator();
    // Load the instance and then the numeric argument, then store the
    // argument in the field.
    numberSetIL->Emit(OpCodes::Ldarg_0);
    numberSetIL->Emit(OpCodes::Ldarg_1);
    numberSetIL->Emit(OpCodes::Stfld, fbNumber);
    numberSetIL->Emit(OpCodes::Ret);
      
    // Last, map the "get" and "set" accessor methods to the 
    // PropertyBuilder. The property is now complete. 
    pbNumber->SetGetMethod(mbNumberGetAccessor);
    pbNumber->SetSetMethod(mbNumberSetAccessor);

    // Define a method that accepts an integer argument and returns
    // the product of that integer and the private field m_number. This
    // time, the array of parameter types is created on the fly.
    MethodBuilder^ meth = tb->DefineMethod(
        "MyMethod", 
        MethodAttributes::Public, 
        int::typeid, 
        gcnew array<Type^> { int::typeid });

    ILGenerator^ methIL = meth->GetILGenerator();
    // To retrieve the private instance field, load the instance it
    // belongs to (argument zero). After loading the field, load the 
    // argument one and then multiply. Return from the method with 
    // the return value (the product of the two numbers) on the 
    // execution stack.
    methIL->Emit(OpCodes::Ldarg_0);
    methIL->Emit(OpCodes::Ldfld, fbNumber);
    methIL->Emit(OpCodes::Ldarg_1);
    methIL->Emit(OpCodes::Mul);
    methIL->Emit(OpCodes::Ret);

    // Finish the type->
    Type^ t = tb->CreateType();
     
    // The following line saves the single-module assembly. This
    // requires AssemblyBuilderAccess to include Save. You can now
    // type "ildasm MyDynamicAsm.dll" at the command prompt, and 
    // examine the assembly. You can also write a program that has
    // a reference to the assembly, and use the MyDynamicType type.
    // 
    ab->Save(aName->Name + ".dll");

    // Because AssemblyBuilderAccess includes Run, the code can be
    // executed immediately. Start by getting reflection objects for
    // the method and the property.
    MethodInfo^ mi = t->GetMethod("MyMethod");
    PropertyInfo^ pi = t->GetProperty("Number");
  
    // Create an instance of MyDynamicType using the default 
    // constructor. 
    Object^ o1 = Activator::CreateInstance(t);

    // Display the value of the property, then change it to 127 and 
    // display it again. Use nullptr to indicate that the property
    // has no index.
    Console::WriteLine("o1->Number: {0}", pi->GetValue(o1, nullptr));
    pi->SetValue(o1, 127, nullptr);
    Console::WriteLine("o1->Number: {0}", pi->GetValue(o1, nullptr));

    // Call MyMethod, passing 22, and display the return value, 22
    // times 127. Arguments must be passed as an array, even when
    // there is only one.
    array<Object^>^ arguments = { 22 };
    Console::WriteLine("o1->MyMethod(22): {0}", 
        mi->Invoke(o1, arguments));

    // Create an instance of MyDynamicType using the constructor
    // that specifies m_Number. The constructor is identified by
    // matching the types in the argument array. In this case, 
    // the argument array is created on the fly. Display the 
    // property value.
    Object^ o2 = Activator::CreateInstance(t, 
        gcnew array<Object^> { 5280 });
    Console::WriteLine("o2->Number: {0}", pi->GetValue(o2, nullptr));
};

/* This code produces the following output:

o1->Number: 42
o1->Number: 127
o1->MyMethod(22): 2794
o2->Number: 5280
 */
using System;
using System.Reflection;
using System.Reflection.Emit;

class DemoAssemblyBuilder
{
    public static void Main()
    {
        // An assembly consists of one or more modules, each of which
        // contains zero or more types. This code creates a single-module
        // assembly, the most common case. The module contains one type,
        // named "MyDynamicType", that has a private field, a property
        // that gets and sets the private field, constructors that
        // initialize the private field, and a method that multiplies
        // a user-supplied number by the private field value and returns
        // the result. In C# the type might look like this:
        /*
        public class MyDynamicType
        {
            private int m_number;

            public MyDynamicType() : this(42) {}
            public MyDynamicType(int initNumber)
            {
                m_number = initNumber;
            }

            public int Number
            {
                get { return m_number; }
                set { m_number = value; }
            }

            public int MyMethod(int multiplier)
            {
                return m_number * multiplier;
            }
        }
        */

        AssemblyName aName = new AssemblyName("DynamicAssemblyExample");
        AssemblyBuilder ab =
            AppDomain.CurrentDomain.DefineDynamicAssembly(
                aName,
                AssemblyBuilderAccess.RunAndSave);

        // For a single-module assembly, the module name is usually
        // the assembly name plus an extension.
        ModuleBuilder mb =
            ab.DefineDynamicModule(aName.Name, aName.Name + ".dll");

        TypeBuilder tb = mb.DefineType(
            "MyDynamicType",
             TypeAttributes.Public);

        // Add a private field of type int (Int32).
        FieldBuilder fbNumber = tb.DefineField(
            "m_number",
            typeof(int),
            FieldAttributes.Private);

        // Define a constructor that takes an integer argument and
        // stores it in the private field.
        Type[] parameterTypes = { typeof(int) };
        ConstructorBuilder ctor1 = tb.DefineConstructor(
            MethodAttributes.Public,
            CallingConventions.Standard,
            parameterTypes);

        ILGenerator ctor1IL = ctor1.GetILGenerator();
        // For a constructor, argument zero is a reference to the new
        // instance. Push it on the stack before calling the base
        // class constructor. Specify the default constructor of the
        // base class (System.Object) by passing an empty array of
        // types (Type.EmptyTypes) to GetConstructor.
        ctor1IL.Emit(OpCodes.Ldarg_0);
        ctor1IL.Emit(OpCodes.Call,
            typeof(object).GetConstructor(Type.EmptyTypes));
        // Push the instance on the stack before pushing the argument
        // that is to be assigned to the private field m_number.
        ctor1IL.Emit(OpCodes.Ldarg_0);
        ctor1IL.Emit(OpCodes.Ldarg_1);
        ctor1IL.Emit(OpCodes.Stfld, fbNumber);
        ctor1IL.Emit(OpCodes.Ret);

        // Define a default constructor that supplies a default value
        // for the private field. For parameter types, pass the empty
        // array of types or pass null.
        ConstructorBuilder ctor0 = tb.DefineConstructor(
            MethodAttributes.Public,
            CallingConventions.Standard,
            Type.EmptyTypes);

        ILGenerator ctor0IL = ctor0.GetILGenerator();
        // For a constructor, argument zero is a reference to the new
        // instance. Push it on the stack before pushing the default
        // value on the stack, then call constructor ctor1.
        ctor0IL.Emit(OpCodes.Ldarg_0);
        ctor0IL.Emit(OpCodes.Ldc_I4_S, 42);
        ctor0IL.Emit(OpCodes.Call, ctor1);
        ctor0IL.Emit(OpCodes.Ret);

        // Define a property named Number that gets and sets the private
        // field.
        //
        // The last argument of DefineProperty is null, because the
        // property has no parameters. (If you don't specify null, you must
        // specify an array of Type objects. For a parameterless property,
        // use the built-in array with no elements: Type.EmptyTypes)
        PropertyBuilder pbNumber = tb.DefineProperty(
            "Number",
            PropertyAttributes.HasDefault,
            typeof(int),
            null);

        // The property "set" and property "get" methods require a special
        // set of attributes.
        MethodAttributes getSetAttr = MethodAttributes.Public |
            MethodAttributes.SpecialName | MethodAttributes.HideBySig;

        // Define the "get" accessor method for Number. The method returns
        // an integer and has no arguments. (Note that null could be
        // used instead of Types.EmptyTypes)
        MethodBuilder mbNumberGetAccessor = tb.DefineMethod(
            "get_Number",
            getSetAttr,
            typeof(int),
            Type.EmptyTypes);

        ILGenerator numberGetIL = mbNumberGetAccessor.GetILGenerator();
        // For an instance property, argument zero is the instance. Load the
        // instance, then load the private field and return, leaving the
        // field value on the stack.
        numberGetIL.Emit(OpCodes.Ldarg_0);
        numberGetIL.Emit(OpCodes.Ldfld, fbNumber);
        numberGetIL.Emit(OpCodes.Ret);

        // Define the "set" accessor method for Number, which has no return
        // type and takes one argument of type int (Int32).
        MethodBuilder mbNumberSetAccessor = tb.DefineMethod(
            "set_Number",
            getSetAttr,
            null,
            new Type[] { typeof(int) });

        ILGenerator numberSetIL = mbNumberSetAccessor.GetILGenerator();
        // Load the instance and then the numeric argument, then store the
        // argument in the field.
        numberSetIL.Emit(OpCodes.Ldarg_0);
        numberSetIL.Emit(OpCodes.Ldarg_1);
        numberSetIL.Emit(OpCodes.Stfld, fbNumber);
        numberSetIL.Emit(OpCodes.Ret);

        // Last, map the "get" and "set" accessor methods to the
        // PropertyBuilder. The property is now complete.
        pbNumber.SetGetMethod(mbNumberGetAccessor);
        pbNumber.SetSetMethod(mbNumberSetAccessor);

        // Define a method that accepts an integer argument and returns
        // the product of that integer and the private field m_number. This
        // time, the array of parameter types is created on the fly.
        MethodBuilder meth = tb.DefineMethod(
            "MyMethod",
            MethodAttributes.Public,
            typeof(int),
            new Type[] { typeof(int) });

        ILGenerator methIL = meth.GetILGenerator();
        // To retrieve the private instance field, load the instance it
        // belongs to (argument zero). After loading the field, load the
        // argument one and then multiply. Return from the method with
        // the return value (the product of the two numbers) on the
        // execution stack.
        methIL.Emit(OpCodes.Ldarg_0);
        methIL.Emit(OpCodes.Ldfld, fbNumber);
        methIL.Emit(OpCodes.Ldarg_1);
        methIL.Emit(OpCodes.Mul);
        methIL.Emit(OpCodes.Ret);

        // Finish the type.
        Type t = tb.CreateType();

        // The following line saves the single-module assembly. This
        // requires AssemblyBuilderAccess to include Save. You can now
        // type "ildasm MyDynamicAsm.dll" at the command prompt, and
        // examine the assembly. You can also write a program that has
        // a reference to the assembly, and use the MyDynamicType type.
        //
        ab.Save(aName.Name + ".dll");

        // Because AssemblyBuilderAccess includes Run, the code can be
        // executed immediately. Start by getting reflection objects for
        // the method and the property.
        MethodInfo mi = t.GetMethod("MyMethod");
        PropertyInfo pi = t.GetProperty("Number");

        // Create an instance of MyDynamicType using the default
        // constructor.
        object o1 = Activator.CreateInstance(t);

        // Display the value of the property, then change it to 127 and
        // display it again. Use null to indicate that the property
        // has no index.
        Console.WriteLine("o1.Number: {0}", pi.GetValue(o1, null));
        pi.SetValue(o1, 127, null);
        Console.WriteLine("o1.Number: {0}", pi.GetValue(o1, null));

        // Call MyMethod, passing 22, and display the return value, 22
        // times 127. Arguments must be passed as an array, even when
        // there is only one.
        object[] arguments = { 22 };
        Console.WriteLine("o1.MyMethod(22): {0}",
            mi.Invoke(o1, arguments));

        // Create an instance of MyDynamicType using the constructor
        // that specifies m_Number. The constructor is identified by
        // matching the types in the argument array. In this case,
        // the argument array is created on the fly. Display the
        // property value.
        object o2 = Activator.CreateInstance(t,
            new object[] { 5280 });
        Console.WriteLine("o2.Number: {0}", pi.GetValue(o2, null));
    }
}

/* This code produces the following output:

o1.Number: 42
o1.Number: 127
o1.MyMethod(22): 2794
o2.Number: 5280
 */
Imports System.Reflection
Imports System.Reflection.Emit

Class DemoAssemblyBuilder

    Public Shared Sub Main()

        ' An assembly consists of one or more modules, each of which
        ' contains zero or more types. This code creates a single-module
        ' assembly, the most common case. The module contains one type,
        ' named "MyDynamicType", that has a private field, a property 
        ' that gets and sets the private field, constructors that 
        ' initialize the private field, and a method that multiplies
        ' a user-supplied number by the private field value and returns 
        ' the result. The code might look like this in Visual Basic:
        '
        'Public Class MyDynamicType
        '    Private m_number As Integer
        '
        '    Public Sub New()
        '        Me.New(42)
        '    End Sub
        '
        '    Public Sub New(ByVal initNumber As Integer)
        '        m_number = initNumber
        '    End Sub
        '
        '    Public Property Number As Integer
        '        Get
        '            Return m_number
        '        End Get
        '        Set
        '            m_Number = Value
        '        End Set
        '    End Property
        '
        '    Public Function MyMethod(ByVal multiplier As Integer) As Integer
        '        Return m_Number * multiplier
        '    End Function
        'End Class
      
        Dim aName As New AssemblyName("DynamicAssemblyExample")
        Dim ab As AssemblyBuilder = _
            AppDomain.CurrentDomain.DefineDynamicAssembly( _
                aName, _
                AssemblyBuilderAccess.RunAndSave)

        ' For a single-module assembly, the module name is usually
        ' the assembly name plus an extension.
        Dim mb As ModuleBuilder = ab.DefineDynamicModule( _
            aName.Name, _
            aName.Name & ".dll")
      
        Dim tb As TypeBuilder = _
            mb.DefineType("MyDynamicType", TypeAttributes.Public)

        ' Add a private field of type Integer (Int32).
        Dim fbNumber As FieldBuilder = tb.DefineField( _
            "m_number", _
            GetType(Integer), _
            FieldAttributes.Private)

        ' Define a constructor that takes an integer argument and 
        ' stores it in the private field. 
        Dim parameterTypes() As Type = { GetType(Integer) }
        Dim ctor1 As ConstructorBuilder = _
            tb.DefineConstructor( _
                MethodAttributes.Public, _
                CallingConventions.Standard, _
                parameterTypes)

        Dim ctor1IL As ILGenerator = ctor1.GetILGenerator()
        ' For a constructor, argument zero is a reference to the new
        ' instance. Push it on the stack before calling the base
        ' class constructor. Specify the default constructor of the 
        ' base class (System.Object) by passing an empty array of 
        ' types (Type.EmptyTypes) to GetConstructor.
        ctor1IL.Emit(OpCodes.Ldarg_0)
        ctor1IL.Emit(OpCodes.Call, _
            GetType(Object).GetConstructor(Type.EmptyTypes))
        ' Push the instance on the stack before pushing the argument
        ' that is to be assigned to the private field m_number.
        ctor1IL.Emit(OpCodes.Ldarg_0)
        ctor1IL.Emit(OpCodes.Ldarg_1)
        ctor1IL.Emit(OpCodes.Stfld, fbNumber)
        ctor1IL.Emit(OpCodes.Ret)

        ' Define a default constructor that supplies a default value
        ' for the private field. For parameter types, pass the empty
        ' array of types or pass Nothing.
        Dim ctor0 As ConstructorBuilder = tb.DefineConstructor( _
            MethodAttributes.Public, _
            CallingConventions.Standard, _
            Type.EmptyTypes)

        Dim ctor0IL As ILGenerator = ctor0.GetILGenerator()
        ' For a constructor, argument zero is a reference to the new
        ' instance. Push it on the stack before pushing the default
        ' value on the stack, then call constructor ctor1.
        ctor0IL.Emit(OpCodes.Ldarg_0)
        ctor0IL.Emit(OpCodes.Ldc_I4_S, 42)
        ctor0IL.Emit(OpCodes.Call, ctor1)
        ctor0IL.Emit(OpCodes.Ret)

        ' Define a property named Number that gets and sets the private 
        ' field.
        '
        ' The last argument of DefineProperty is Nothing, because the
        ' property has no parameters. (If you don't specify Nothing, you must
        ' specify an array of Type objects. For a parameterless property,
        ' use the built-in array with no elements: Type.EmptyTypes)
        Dim pbNumber As PropertyBuilder = tb.DefineProperty( _
            "Number", _
            PropertyAttributes.HasDefault, _
            GetType(Integer), _
            Nothing)
      
        ' The property Set and property Get methods require a special
        ' set of attributes.
        Dim getSetAttr As MethodAttributes = _
            MethodAttributes.Public Or MethodAttributes.SpecialName _
                Or MethodAttributes.HideBySig

        ' Define the "get" accessor method for Number. The method returns
        ' an integer and has no arguments. (Note that Nothing could be 
        ' used instead of Types.EmptyTypes)
        Dim mbNumberGetAccessor As MethodBuilder = tb.DefineMethod( _
            "get_Number", _
            getSetAttr, _
            GetType(Integer), _
            Type.EmptyTypes)
      
        Dim numberGetIL As ILGenerator = mbNumberGetAccessor.GetILGenerator()
        ' For an instance property, argument zero is the instance. Load the 
        ' instance, then load the private field and return, leaving the
        ' field value on the stack.
        numberGetIL.Emit(OpCodes.Ldarg_0)
        numberGetIL.Emit(OpCodes.Ldfld, fbNumber)
        numberGetIL.Emit(OpCodes.Ret)
        
        ' Define the "set" accessor method for Number, which has no return
        ' type and takes one argument of type Integer (Int32).
        Dim mbNumberSetAccessor As MethodBuilder = _
            tb.DefineMethod( _
                "set_Number", _
                getSetAttr, _
                Nothing, _
                New Type() { GetType(Integer) })
      
        Dim numberSetIL As ILGenerator = mbNumberSetAccessor.GetILGenerator()
        ' Load the instance and then the numeric argument, then store the
        ' argument in the field.
        numberSetIL.Emit(OpCodes.Ldarg_0)
        numberSetIL.Emit(OpCodes.Ldarg_1)
        numberSetIL.Emit(OpCodes.Stfld, fbNumber)
        numberSetIL.Emit(OpCodes.Ret)
      
        ' Last, map the "get" and "set" accessor methods to the 
        ' PropertyBuilder. The property is now complete. 
        pbNumber.SetGetMethod(mbNumberGetAccessor)
        pbNumber.SetSetMethod(mbNumberSetAccessor)

        ' Define a method that accepts an integer argument and returns
        ' the product of that integer and the private field m_number. This
        ' time, the array of parameter types is created on the fly.
        Dim meth As MethodBuilder = tb.DefineMethod( _
            "MyMethod", _
            MethodAttributes.Public, _
            GetType(Integer), _
            New Type() { GetType(Integer) })

        Dim methIL As ILGenerator = meth.GetILGenerator()
        ' To retrieve the private instance field, load the instance it
        ' belongs to (argument zero). After loading the field, load the 
        ' argument one and then multiply. Return from the method with 
        ' the return value (the product of the two numbers) on the 
        ' execution stack.
        methIL.Emit(OpCodes.Ldarg_0)
        methIL.Emit(OpCodes.Ldfld, fbNumber)
        methIL.Emit(OpCodes.Ldarg_1)
        methIL.Emit(OpCodes.Mul)
        methIL.Emit(OpCodes.Ret)

        ' Finish the type.
        Dim t As Type = tb.CreateType()
     
        ' The following line saves the single-module assembly. This
        ' requires AssemblyBuilderAccess to include Save. You can now
        ' type "ildasm MyDynamicAsm.dll" at the command prompt, and 
        ' examine the assembly. You can also write a program that has
        ' a reference to the assembly, and use the MyDynamicType type.
        ' 
        ab.Save(aName.Name & ".dll") 

        ' Because AssemblyBuilderAccess includes Run, the code can be
        ' executed immediately. Start by getting reflection objects for
        ' the method and the property.
        Dim mi As MethodInfo = t.GetMethod("MyMethod")
        Dim pi As PropertyInfo = t.GetProperty("Number")
  
        ' Create an instance of MyDynamicType using the default 
        ' constructor. 
        Dim o1 As Object = Activator.CreateInstance(t)

        ' Display the value of the property, then change it to 127 and 
        ' display it again. Use Nothing to indicate that the property
        ' has no index.
        Console.WriteLine("o1.Number: {0}", pi.GetValue(o1, Nothing))
        pi.SetValue(o1, 127, Nothing)
        Console.WriteLine("o1.Number: {0}", pi.GetValue(o1, Nothing))

        ' Call MyMethod, passing 22, and display the return value, 22
        ' times 127. Arguments must be passed as an array, even when
        ' there is only one.
        Dim arguments() As Object = { 22 }
        Console.WriteLine("o1.MyMethod(22): {0}", _
            mi.Invoke(o1, arguments))

        ' Create an instance of MyDynamicType using the constructor
        ' that specifies m_Number. The constructor is identified by
        ' matching the types in the argument array. In this case, 
        ' the argument array is created on the fly. Display the 
        ' property value.
        Dim o2 As Object = Activator.CreateInstance(t, _
            New Object() { 5280 })
        Console.WriteLine("o2.Number: {0}", pi.GetValue(o2, Nothing))
      
    End Sub  
End Class

' This code produces the following output:
'
'o1.Number: 42
'o1.Number: 127
'o1.MyMethod(22): 2794
'o2.Number: 5280

Comentarios

Un ensamblado dinámico es un ensamblado que se crea mediante las API de emisión de la reflexión.A dynamic assembly is an assembly that is created using the Reflection Emit APIs. Los módulos dinámicos del ensamblado se guardan cuando el ensamblado dinámico se guarda con el Save método.The dynamic modules in the assembly are saved when the dynamic assembly is saved using the Save method. Para generar un archivo ejecutable, SetEntryPoint se debe llamar al método para identificar el método que es el punto de entrada del ensamblado.To generate an executable, the SetEntryPoint method must be called to identify the method that is the entry point to the assembly. De forma predeterminada, los ensamblados se guardan como archivos dll, a menos que el SetEntryPoint método solicite la generación de una aplicación de consola o una aplicación basada en Windows.Assemblies are saved as DLLs by default, unless the SetEntryPoint method requests the generation of a console application or a Windows-based application.

Si un ensamblado dinámico contiene más de un módulo dinámico, el nombre del archivo de manifiesto del ensamblado debe coincidir con el nombre del módulo que se especifica como primer argumento del DefineDynamicModule método.If a dynamic assembly contains more than one dynamic module, the assembly's manifest file name should match the module's name that is specified as the first argument to the DefineDynamicModule method.

Algunos métodos de la Assembly clase base, como GetModules y GetLoadedModules , no funcionarán correctamente cuando se llamen desde AssemblyBuilder objetos.Some methods on the base Assembly class, such as GetModules and GetLoadedModules, will not work correctly when called from AssemblyBuilder objects. Puede cargar el ensamblado dinámico definido y llamar a los métodos en el ensamblado cargado.You can load the defined dynamic assembly and call the methods on the loaded assembly. Por ejemplo, para asegurarse de que los módulos de recursos se incluyen en la lista de módulos devueltos, llame a GetModules en el Assembly objeto cargado.For example, to ensure that resource modules are included in the returned module list, call GetModules on the loaded Assembly object.

La firma de un ensamblado dinámico mediante KeyPair no es efectiva hasta que el ensamblado se guarda en el disco.The signing of a dynamic assembly using KeyPair is not effective until the assembly is saved to disk. Por lo tanto, los nombres seguros no funcionarán con ensamblados dinámicos transitorios.So, strong names will not work with transient dynamic assemblies.

Para obtener un AssemblyBuilder objeto, use el AppDomain.DefineDynamicAssembly método.To get an AssemblyBuilder object, use the AppDomain.DefineDynamicAssembly method.

Escenarios de ensamblado dinámico de emisión de la reflexiónReflection emit dynamic assembly scenarios

A continuación se indican algunos aspectos que se deben tener en cuenta al usar la AssemblyBuilder clase para crear ensamblados dinámicos.The following are some things to consider when using the AssemblyBuilder class to create dynamic assemblies.

Módulos dinámicosDynamic modules

La emisión de la reflexión admite la creación de módulos dinámicos definidos en ensamblados dinámicos.Reflection emit supports the creation of dynamic modules defined in dynamic assemblies. Un módulo dinámico creado en un ensamblado dinámico puede ser transitorio o persistente.A dynamic module created in a dynamic assembly can be transient or persistable.

Restricciones en las referencias de tipoRestrictions on type references

Los ensamblados pueden hacer referencia a los tipos definidos en otro ensamblado.Assemblies can reference types defined in another assembly. Un ensamblado dinámico transitorio puede hacer referencia de forma segura a los tipos definidos en otro ensamblado dinámico transitorio, un ensamblado dinámico con persistencia o un ensamblado estático.A transient dynamic assembly can safely reference types defined in another transient dynamic assembly, a persistable dynamic assembly, or a static assembly. Sin embargo, el Common Language Runtime no permite que un módulo dinámico con persistencia haga referencia a un tipo definido en un módulo dinámico transitorio.However, the common language runtime does not allow a persistable dynamic module to reference a type defined in a transient dynamic module. Esto se debe a que cuando se carga el módulo dinámico persistente después de guardarlo en el disco, el runtime no puede resolver las referencias a los tipos definidos en el módulo dinámico transitorio.This is because when the persisted dynamic module is loaded after being saved to disk, the runtime cannot resolve the references to types defined in the transient dynamic module.

Restricciones en la emisión a dominios de aplicación remotosRestrictions on emitting to remote application domains

Algunos escenarios requieren la creación y ejecución de un ensamblado dinámico en un dominio de aplicación remoto.Some scenarios require a dynamic assembly to be created and executed in a remote application domain. La emisión de la reflexión no permite que un ensamblado dinámico se emita directamente a un dominio de aplicación remoto.Reflection emit does not allow a dynamic assembly to be emitted directly to a remote application domain. La solución consiste en emitir el ensamblado dinámico en el dominio de aplicación actual, guardar el ensamblado dinámico emitido en el disco y, a continuación, cargar el ensamblado dinámico en el dominio de aplicación remoto.The solution is to emit the dynamic assembly in the current application domain, save the emitted dynamic assembly to disk, and then load the dynamic assembly into the remote application domain.

Modos de acceso a ensamblados dinámicosDynamic assembly access modes

Los ensamblados dinámicos se pueden crear con uno de los siguientes modos de acceso:Dynamic assemblies can be created using one of the following access modes:

  • AssemblyBuilderAccess.Run

    El ensamblado dinámico representado por un AssemblyBuilder objeto es transitorio.The dynamic assembly represented by an AssemblyBuilder object is transient. El ensamblado dinámico solo se puede usar para ejecutar el código emitido.The dynamic assembly can only be used to execute the emitted code.

  • AssemblyBuilderAccess.Save

    El ensamblado dinámico representado por un AssemblyBuilder objeto es persistente pero no se puede ejecutar hasta que se haya cargado desde el disco el archivo ejecutable portable (PE) guardado.The dynamic assembly represented by an AssemblyBuilder object is persistable but cannot be executed until the saved portable executable (PE) file has been loaded from disk.

  • AssemblyBuilderAccess.RunAndSave

    El ensamblado dinámico representado por un AssemblyBuilder objeto es persistente, pero también se puede ejecutar antes o después de que el ensamblado se guarde en el disco.The dynamic assembly represented by an AssemblyBuilder object is persistable, but can also be executed before and/or after the assembly is saved to disk.

El modo de acceso se debe especificar proporcionando el AssemblyBuilderAccess valor adecuado en la llamada al AssemblyBuilder.DefineDynamicAssembly método cuando el ensamblado dinámico está definido y no se puede cambiar más adelante.The access mode must be specified by providing the appropriate AssemblyBuilderAccess value in the call to the AssemblyBuilder.DefineDynamicAssembly method when the dynamic assembly is defined and cannot be changed later. El motor en tiempo de ejecución utiliza el modo de acceso de un ensamblado dinámico para optimizar la representación interna del ensamblado.The runtime uses the access mode of a dynamic assembly to optimize the assembly's internal representation.

Constructores

AssemblyBuilder()

Propiedades

CodeBase

Obtiene la ubicación del ensamblado tal y como se especificó originalmente (como en un objeto AssemblyName).Gets the location of the assembly, as specified originally (such as in an AssemblyName object).

CodeBase

Obtiene la ubicación del ensamblado tal como se especificó originalmente, por ejemplo, en un objeto AssemblyName.Gets the location of the assembly as specified originally, for example, in an AssemblyName object.

(Heredado de Assembly)
CustomAttributes

Obtiene una colección que contiene los atributos personalizados de este ensamblado.Gets a collection that contains this assembly's custom attributes.

(Heredado de Assembly)
DefinedTypes
DefinedTypes

Obtiene una colección de los tipos definidos en este ensamblado.Gets a collection of the types defined in this assembly.

(Heredado de Assembly)
EntryPoint

Devuelve el punto de entrada de este ensamblado.Returns the entry point of this assembly.

EntryPoint

Obtiene el punto de entrada de este ensamblado.Gets the entry point of this assembly.

(Heredado de Assembly)
EscapedCodeBase

Obtiene el identificador URI, incluidos los caracteres de escape, que representa el código base.Gets the URI, including escape characters, that represents the codebase.

(Heredado de Assembly)
Evidence

Obtiene la evidencia para este ensamblado.Gets the evidence for this assembly.

Evidence

Obtiene la evidencia para este ensamblado.Gets the evidence for this assembly.

(Heredado de Assembly)
ExportedTypes

Obtiene una colección de los tipos públicos definidos en este ensamblado que se pueden ver desde fuera del ensamblado.Gets a collection of the public types defined in this assembly that are visible outside the assembly.

(Heredado de Assembly)
FullName

Obtiene el nombre para mostrar del ensamblado dinámico actual.Gets the display name of the current dynamic assembly.

FullName

Obtiene el nombre para mostrar del ensamblado.Gets the display name of the assembly.

(Heredado de Assembly)
GlobalAssemblyCache

Obtiene un valor que indica si el ensamblado se ha cargado desde la caché global de ensamblados.Gets a value that indicates whether the assembly was loaded from the global assembly cache.

GlobalAssemblyCache

Obtiene un valor que indica si el ensamblado se ha cargado desde la caché global de ensamblados.Gets a value indicating whether the assembly was loaded from the global assembly cache.

(Heredado de Assembly)
HostContext

Obtiene el contexto del host donde se está creando el ensamblado dinámico.Gets the host context where the dynamic assembly is being created.

HostContext

Obtiene el contexto del host con el que se cargó el ensamblado.Gets the host context with which the assembly was loaded.

(Heredado de Assembly)
ImageRuntimeVersion

Obtiene l versión de Common Language Runtime (CLR) que se guardará en el archivo que contiene el manifiesto.Gets the version of the common language runtime that will be saved in the file containing the manifest.

ImageRuntimeVersion

Obtiene una cadena que representa la versión de Common Language Runtime (CLR) guardada en el archivo que contiene el manifiesto.Gets a string representing the version of the common language runtime (CLR) saved in the file containing the manifest.

(Heredado de Assembly)
IsCollectible

Obtiene un valor que indica si este ensamblado está contenido en un AssemblyLoadContext recopilable.Gets a value that indicates whether this assembly is held in a collectible AssemblyLoadContext.

(Heredado de Assembly)
IsDynamic

Obtiene un valor que indica que el ensamblado actual es un ensamblado dinámico.Gets a value that indicates that the current assembly is a dynamic assembly.

IsDynamic

Obtiene un valor que indica si el ensamblado actual se generó dinámicamente en el proceso actual utilizando emisión de la reflexión.Gets a value that indicates whether the current assembly was generated dynamically in the current process by using reflection emit.

(Heredado de Assembly)
IsFullyTrusted

Obtiene un valor que indica si el ensamblado actual se carga con plena confianza.Gets a value that indicates whether the current assembly is loaded with full trust.

(Heredado de Assembly)
Location

Obtiene la ubicación, en formato de código base, del archivo cargado que contiene el manifiesto si no se han creado instantáneas.Gets the location, in codebase format, of the loaded file that contains the manifest if it is not shadow-copied.

Location

Obtiene la ruta de acceso completa o la ubicación UNC del archivo cargado que contiene el manifiesto.Gets the full path or UNC location of the loaded file that contains the manifest.

(Heredado de Assembly)
ManifestModule

Obtiene el módulo del AssemblyBuilder actual que contiene el manifiesto del ensamblado.Gets the module in the current AssemblyBuilder that contains the assembly manifest.

ManifestModule

Obtiene el módulo que contiene el manifiesto del ensamblado actual.Gets the module that contains the manifest for the current assembly.

(Heredado de Assembly)
Modules
Modules

Obtiene una colección que contiene los módulos de este ensamblado.Gets a collection that contains the modules in this assembly.

(Heredado de Assembly)
PermissionSet

Obtiene el conjunto de permisos del ensamblado dinámico actual.Gets the grant set of the current dynamic assembly.

PermissionSet

Obtiene el conjunto de permisos del ensamblado actual.Gets the grant set of the current assembly.

(Heredado de Assembly)
ReflectionOnly

Obtiene un valor que indica si el ensamblado dinámico está en el contexto de solo reflexión.Gets a value indicating whether the dynamic assembly is in the reflection-only context.

ReflectionOnly

Obtiene un valor Boolean que indica si este ensamblado se cargó en el contexto de solo reflexión.Gets a Boolean value indicating whether this assembly was loaded into the reflection-only context.

(Heredado de Assembly)
SecurityRuleSet

Obtiene un valor que indica el conjunto de reglas de seguridad que Common Language Runtime (CLR) aplica para este ensamblado.Gets a value that indicates which set of security rules the common language runtime (CLR) enforces for this assembly.

SecurityRuleSet

Obtiene un valor que indica el conjunto de reglas de seguridad que Common Language Runtime (CLR) aplica para este ensamblado.Gets a value that indicates which set of security rules the common language runtime (CLR) enforces for this assembly.

(Heredado de Assembly)

Métodos

AddResourceFile(String, String)

Agrega un archivo de recursos existente a este ensamblado.Adds an existing resource file to this assembly.

AddResourceFile(String, String, ResourceAttributes)

Agrega un archivo de recursos existente a este ensamblado.Adds an existing resource file to this assembly.

CreateInstance(String)

Localiza el tipo especificado en este ensamblado y crea una instancia del tipo mediante el activador del sistema, realizando una búsqueda en la que se distingue entre mayúsculas y minúsculas.Locates the specified type from this assembly and creates an instance of it using the system activator, using case-sensitive search.

(Heredado de Assembly)
CreateInstance(String, Boolean)

Ubica el tipo especificado de este ensamblado y crea una instancia de dicho tipo mediante el activador del sistema, con búsqueda de mayúsculas y minúsculas opcional.Locates the specified type from this assembly and creates an instance of it using the system activator, with optional case-sensitive search.

(Heredado de Assembly)
CreateInstance(String, Boolean, BindingFlags, Binder, Object[], CultureInfo, Object[])

Ubica el tipo especificado en este ensamblado y crea una instancia de dicho tipo mediante el activador del sistema, con búsqueda de mayúsculas y minúsculas opcional y con los atributos de referencia cultural, argumentos, enlace y activación.Locates the specified type from this assembly and creates an instance of it using the system activator, with optional case-sensitive search and having the specified culture, arguments, and binding and activation attributes.

(Heredado de Assembly)
DefineDynamicAssembly(AssemblyName, AssemblyBuilderAccess)

Define un ensamblado dinámico con el nombre y los derechos de acceso especificados.Defines a dynamic assembly that has the specified name and access rights.

DefineDynamicAssembly(AssemblyName, AssemblyBuilderAccess, IEnumerable<CustomAttributeBuilder>)

Define un nuevo ensamblado con el nombre, los derechos de acceso y los atributos especificados.Defines a new assembly that has the specified name, access rights, and attributes.

DefineDynamicModule(String)

Define un módulo dinámico transitorio con nombre en este ensamblado.Defines a named transient dynamic module in this assembly.

DefineDynamicModule(String, Boolean)

Define un módulo dinámico transitorio con nombre en este ensamblado y especifica si se debe emitir información de símbolos.Defines a named transient dynamic module in this assembly and specifies whether symbol information should be emitted.

DefineDynamicModule(String, String)

Define un módulo dinámico con persistencia con el nombre especificado que se guardará en el archivo especificado.Defines a persistable dynamic module with the given name that will be saved to the specified file. No se emitirá información de símbolos.No symbol information is emitted.

DefineDynamicModule(String, String, Boolean)

Define un módulo dinámico con persistencia, especificando el nombre del módulo, el nombre del archivo en el que se guardará el módulo y si se debe emitir información de símbolos mediante el escritor de símbolos predeterminado.Defines a persistable dynamic module, specifying the module name, the name of the file to which the module will be saved, and whether symbol information should be emitted using the default symbol writer.

DefineResource(String, String, String)

Define un recurso administrado independiente para este ensamblado con el atributo de recurso público predeterminado.Defines a standalone managed resource for this assembly with the default public resource attribute.

DefineResource(String, String, String, ResourceAttributes)

Define un recurso administrado independiente para este ensamblado.Defines a standalone managed resource for this assembly. Los atributos se pueden especificar para el recurso administrado.Attributes can be specified for the managed resource.

DefineUnmanagedResource(Byte[])

Define un recurso no administrado para este ensamblado como blob opaco de bytes.Defines an unmanaged resource for this assembly as an opaque blob of bytes.

DefineUnmanagedResource(String)

Define un archivo de recurso no administrado para este ensamblado con el nombre del archivo de recursos.Defines an unmanaged resource file for this assembly given the name of the resource file.

DefineVersionInfoResource()

Define un recurso de información de versión sin administrar mediante la información especificada en el objeto AssemblyName del ensamblado y los atributos personalizados del ensamblado.Defines an unmanaged version information resource using the information specified in the assembly's AssemblyName object and the assembly's custom attributes.

DefineVersionInfoResource(String, String, String, String, String)

Define un recurso de información de versión no administrado para este ensamblado con las especificaciones dadas.Defines an unmanaged version information resource for this assembly with the given specifications.

Equals(Object)

Devuelve un valor que indica si esta instancia es igual al objeto especificado.Returns a value that indicates whether this instance is equal to the specified object.

Equals(Object)

Determina si este ensamblado y el objeto especificado son iguales.Determines whether this assembly and the specified object are equal.

(Heredado de Assembly)
GetCustomAttributes(Boolean)

Devuelve todos los atributos personalizados que se aplicaron al AssemblyBuilder actual.Returns all the custom attributes that have been applied to the current AssemblyBuilder.

GetCustomAttributes(Boolean)

Obtiene todos los atributos personalizados para este ensamblado.Gets all the custom attributes for this assembly.

(Heredado de Assembly)
GetCustomAttributes(Type, Boolean)

Devuelve todos los atributos personalizados que se aplicaron al AssemblyBuilder actual y que derivan de un tipo de atributo especificado.Returns all the custom attributes that have been applied to the current AssemblyBuilder, and that derive from a specified attribute type.

GetCustomAttributes(Type, Boolean)

Obtiene los atributos personalizados para este ensamblado tal y como lo especifica el tipo.Gets the custom attributes for this assembly as specified by type.

(Heredado de Assembly)
GetCustomAttributesData()

Devuelve objetos CustomAttributeData que contienen información sobre los atributos que se aplicaron al AssemblyBuilder actual.Returns CustomAttributeData objects that contain information about the attributes that have been applied to the current AssemblyBuilder.

GetCustomAttributesData()

Devuelve información sobre los atributos que se han aplicado al Assembly actual, expresado como objetos CustomAttributeData.Returns information about the attributes that have been applied to the current Assembly, expressed as CustomAttributeData objects.

(Heredado de Assembly)
GetDynamicModule(String)

Devuelve el módulo dinámico con el nombre especificado.Returns the dynamic module with the specified name.

GetExportedTypes()

Obtiene los tipos definidos en este ensamblado.Gets the exported types defined in this assembly.

GetExportedTypes()

Obtiene los tipos públicos definidos en este ensamblado que se pueden ver desde fuera del ensamblado.Gets the public types defined in this assembly that are visible outside the assembly.

(Heredado de Assembly)
GetFile(String)

Obtiene un objeto FileStream para el archivo especificado en la tabla de archivos del manifiesto de este ensamblado.Gets a FileStream for the specified file in the file table of the manifest of this assembly.

GetFile(String)

Obtiene un objeto FileStream para el archivo especificado en la tabla de archivos del manifiesto de este ensamblado.Gets a FileStream for the specified file in the file table of the manifest of this assembly.

(Heredado de Assembly)
GetFiles()

Obtiene los archivos en la tabla de archivos del manifiesto del ensamblado.Gets the files in the file table of an assembly manifest.

(Heredado de Assembly)
GetFiles(Boolean)

Obtiene los archivos en la tabla de archivos del manifiesto del ensamblado, especificando si deben incluirse módulos de recursos.Gets the files in the file table of an assembly manifest, specifying whether to include resource modules.

GetFiles(Boolean)

Obtiene los archivos en la tabla de archivos del manifiesto del ensamblado, especificando si deben incluirse módulos de recursos.Gets the files in the file table of an assembly manifest, specifying whether to include resource modules.

(Heredado de Assembly)
GetForwardedTypes() (Heredado de Assembly)
GetHashCode()

Devuelve el código hash de esta instancia.Returns the hash code for this instance.

GetHashCode()

Devuelve el código hash de esta instancia.Returns the hash code for this instance.

(Heredado de Assembly)
GetLoadedModules()

Obtiene todos los módulos cargados que forman parte de este ensamblado.Gets all the loaded modules that are part of this assembly.

(Heredado de Assembly)
GetLoadedModules(Boolean)

Devuelve todos los módulos cargados que forman parte de este ensamblado e incluye opcionalmente módulos de recursos.Returns all the loaded modules that are part of this assembly, and optionally includes resource modules.

GetLoadedModules(Boolean)

Obtiene todos los módulos cargados que forman parte de este ensamblado, especificando si se deben incluir módulos de recursos.Gets all the loaded modules that are part of this assembly, specifying whether to include resource modules.

(Heredado de Assembly)
GetManifestResourceInfo(String)

Devuelve información sobre cómo el recurso dado ha persistido.Returns information about how the given resource has been persisted.

GetManifestResourceInfo(String)

Devuelve información sobre cómo el recurso dado ha persistido.Returns information about how the given resource has been persisted.

(Heredado de Assembly)
GetManifestResourceNames()

Carga el recurso del manifiesto especificado a partir de este ensamblado.Loads the specified manifest resource from this assembly.

GetManifestResourceNames()

Devuelve los nombres de todos los recursos de este ensamblado.Returns the names of all the resources in this assembly.

(Heredado de Assembly)
GetManifestResourceStream(String)

Carga el recurso del manifiesto especificado a partir de este ensamblado.Loads the specified manifest resource from this assembly.

GetManifestResourceStream(String)

Carga el recurso del manifiesto especificado a partir de este ensamblado.Loads the specified manifest resource from this assembly.

(Heredado de Assembly)
GetManifestResourceStream(Type, String)

Carga el recurso del manifiesto especificado según el espacio de nombres del tipo especificado a partir de este ensamblado.Loads the specified manifest resource, scoped by the namespace of the specified type, from this assembly.

GetManifestResourceStream(Type, String)

Carga el recurso del manifiesto especificado según el espacio de nombres del tipo especificado a partir de este ensamblado.Loads the specified manifest resource, scoped by the namespace of the specified type, from this assembly.

(Heredado de Assembly)
GetModule(String)

Obtiene el módulo especificado en este ensamblado.Gets the specified module in this assembly.

GetModule(String)

Obtiene el módulo especificado en este ensamblado.Gets the specified module in this assembly.

(Heredado de Assembly)
GetModules()

Obtiene todos los módulos que forman parte de este ensamblado.Gets all the modules that are part of this assembly.

(Heredado de Assembly)
GetModules(Boolean)

Obtiene todos los módulos que forman parte de este ensamblado e incluye opcionalmente módulos de recursos.Gets all the modules that are part of this assembly, and optionally includes resource modules.

GetModules(Boolean)

Obtiene todos los módulos que forman parte de este ensamblado e indica si se deben incluir módulos de recursos.Gets all the modules that are part of this assembly, specifying whether to include resource modules.

(Heredado de Assembly)
GetName()

Obtiene un AssemblyName para este ensamblado.Gets an AssemblyName for this assembly.

(Heredado de Assembly)
GetName(Boolean)

Obtiene el AssemblyName que se especificó cuando se creó el ensamblado dinámico actual y establece el código base según lo especificado.Gets the AssemblyName that was specified when the current dynamic assembly was created, and sets the code base as specified.

GetName(Boolean)

Obtiene un objeto AssemblyName para este ensamblado y establece el código base tal como especifica copiedName.Gets an AssemblyName for this assembly, setting the codebase as specified by copiedName.

(Heredado de Assembly)
GetObjectData(SerializationInfo, StreamingContext)

Obtiene información de serialización con todos los datos necesarios para crear una nueva instancia de este ensamblado.Gets serialization information with all of the data needed to reinstantiate this assembly.

(Heredado de Assembly)
GetReferencedAssemblies()

Obtiene una lista incompleta de objetos AssemblyName para los ensamblados a los que hace referencia este AssemblyBuilder.Gets an incomplete list of AssemblyName objects for the assemblies that are referenced by this AssemblyBuilder.

GetReferencedAssemblies()

Obtiene los objetos AssemblyName de todos los ensamblados a los que hace referencia este ensamblado.Gets the AssemblyName objects for all the assemblies referenced by this assembly.

(Heredado de Assembly)
GetSatelliteAssembly(CultureInfo)

Obtiene el ensamblado satélite para la referencia cultural especificada.Gets the satellite assembly for the specified culture.

GetSatelliteAssembly(CultureInfo)

Obtiene el ensamblado satélite para la referencia cultural especificada.Gets the satellite assembly for the specified culture.

(Heredado de Assembly)
GetSatelliteAssembly(CultureInfo, Version)

Obtiene la versión especificada del ensamblado satélite para la referencia cultural especificada.Gets the specified version of the satellite assembly for the specified culture.

GetSatelliteAssembly(CultureInfo, Version)

Obtiene la versión especificada del ensamblado satélite para la referencia cultural especificada.Gets the specified version of the satellite assembly for the specified culture.

(Heredado de Assembly)
GetType() (Heredado de Assembly)
GetType(String)

Obtiene el objeto Type con el nombre especificado en la instancia de ensamblado.Gets the Type object with the specified name in the assembly instance.

(Heredado de Assembly)
GetType(String, Boolean)

Obtiene el objeto Type con el nombre especificado en la instancia de ensamblado y, de manera opcional, produce una excepción si no se encuentra el tipo.Gets the Type object with the specified name in the assembly instance and optionally throws an exception if the type is not found.

(Heredado de Assembly)
GetType(String, Boolean, Boolean)

Obtiene el tipo especificado a partir de los tipos que se definieron y se crearon en el AssemblyBuilder actual.Gets the specified type from the types that have been defined and created in the current AssemblyBuilder.

GetType(String, Boolean, Boolean)

Obtiene el objeto Type con el nombre especificado en la instancia de ensamblado, con la opción de omitir el caso y de producir una excepción si no se encuentra el tipo.Gets the Type object with the specified name in the assembly instance, with the options of ignoring the case, and of throwing an exception if the type is not found.

(Heredado de Assembly)
GetTypes()

Obtiene los tipos definidos en este ensamblado.Gets the types defined in this assembly.

(Heredado de Assembly)
IsDefined(Type, Boolean)

Devuelve un valor que indica si se aplica a este miembro una o más instancias del tipo de atributo especificado.Returns a value that indicates whether one or more instances of the specified attribute type is applied to this member.

IsDefined(Type, Boolean)

Indica si se ha aplicado un atributo especificado al ensamblado.Indicates whether or not a specified attribute has been applied to the assembly.

(Heredado de Assembly)
LoadModule(String, Byte[])

Carga el módulo, que es interno para este ensamblado, con una imagen que toma como base el formato Common Object File Format (COFF) y que contiene un módulo emitido o un archivo de recursos.Loads the module, internal to this assembly, with a common object file format (COFF)-based image containing an emitted module, or a resource file.

(Heredado de Assembly)
LoadModule(String, Byte[], Byte[])

Carga el módulo, que es interno para este ensamblado, con una imagen que toma como base el formato Common Object File Format (COFF) y que contiene un módulo emitido o un archivo de recursos.Loads the module, internal to this assembly, with a common object file format (COFF)-based image containing an emitted module, or a resource file. También se cargan los bytes sin formato que representan a los símbolos del módulo.The raw bytes representing the symbols for the module are also loaded.

(Heredado de Assembly)
MemberwiseClone()

Crea una copia superficial del Object actual.Creates a shallow copy of the current Object.

(Heredado de Object)
Save(String)

Guarda este ensamblado dinámico en el disco.Saves this dynamic assembly to disk.

Save(String, PortableExecutableKinds, ImageFileMachine)

Guarda este ensamblado dinámico en el disco, especificando la naturaleza del código en los ejecutables del ensamblado y en la plataforma de destino.Saves this dynamic assembly to disk, specifying the nature of code in the assembly's executables and the target platform.

SetCustomAttribute(ConstructorInfo, Byte[])

Establezca un atributo personalizado en este ensamblado mediante un blob de atributo personalizado especificado.Set a custom attribute on this assembly using a specified custom attribute blob.

SetCustomAttribute(CustomAttributeBuilder)

Establezca un atributo personalizado en este ensamblado mediante un generador de atributos personalizado.Set a custom attribute on this assembly using a custom attribute builder.

SetEntryPoint(MethodInfo)

Establece el punto de entrada para este ensamblado dinámico, suponiendo que se está generando una aplicación de consola.Sets the entry point for this dynamic assembly, assuming that a console application is being built.

SetEntryPoint(MethodInfo, PEFileKinds)

Establece el punto de entrada de este ensamblado y define el tipo de archivo ejecutable portátil (archivo PE) que se está generando.Sets the entry point for this assembly and defines the type of the portable executable (PE file) being built.

ToString()

Devuelve el nombre completo del ensamblado, también conocido como nombre para mostrar.Returns the full name of the assembly, also known as the display name.

(Heredado de Assembly)

Eventos

ModuleResolve

Se produce cuando el cargador de clases Common Language Runtime no puede resolver una referencia a un módulo interno de un ensamblado por medios normales.Occurs when the common language runtime class loader cannot resolve a reference to an internal module of an assembly through normal means.

(Heredado de Assembly)

Implementaciones de interfaz explícitas

_Assembly.GetType()

Devuelve el tipo de la instancia actual.Returns the type of the current instance.

(Heredado de Assembly)
_AssemblyBuilder.GetIDsOfNames(Guid, IntPtr, UInt32, UInt32, IntPtr)

Asigna un conjunto de nombres a un conjunto correspondiente de identificadores de envío.Maps a set of names to a corresponding set of dispatch identifiers.

_AssemblyBuilder.GetTypeInfo(UInt32, UInt32, IntPtr)

Recupera la información de tipo de un objeto, que se puede usar después para obtener la información de tipo de una interfaz.Retrieves the type information for an object, which can then be used to get the type information for an interface.

_AssemblyBuilder.GetTypeInfoCount(UInt32)

Recupera el número de interfaces de información de tipo que proporciona un objeto (0 ó 1).Retrieves the number of type information interfaces that an object provides (either 0 or 1).

_AssemblyBuilder.Invoke(UInt32, Guid, UInt32, Int16, IntPtr, IntPtr, IntPtr, IntPtr)

Proporciona acceso a las propiedades y los métodos expuestos por un objeto.Provides access to properties and methods exposed by an object.

ICustomAttributeProvider.GetCustomAttributes(Boolean)

Devuelve una matriz de todos los atributos personalizados definidos en este miembro, excluidos los atributos con nombre, o una matriz vacía si no hay atributos personalizados.Returns an array of all of the custom attributes defined on this member, excluding named attributes, or an empty array if there are no custom attributes.

(Heredado de Assembly)
ICustomAttributeProvider.GetCustomAttributes(Type, Boolean)

Devuelve una matriz de atributos personalizados definidos en este miembro, identificados por tipo, o una matriz vacía si no hay atributos personalizados de ese tipo.Returns an array of custom attributes defined on this member, identified by type, or an empty array if there are no custom attributes of that type.

(Heredado de Assembly)
ICustomAttributeProvider.IsDefined(Type, Boolean)

Indica si una o más instancias de attributeType se definen en este miembro.Indicates whether one or more instance of attributeType is defined on this member.

(Heredado de Assembly)

Métodos de extensión

GetExportedTypes(Assembly)
GetModules(Assembly)
GetTypes(Assembly)
GetCustomAttribute(Assembly, Type)

Recupera un atributo personalizado de un tipo especificado que se aplica a un ensamblado concreto.Retrieves a custom attribute of a specified type that is applied to a specified assembly.

GetCustomAttribute<T>(Assembly)

Recupera un atributo personalizado de un tipo especificado que se aplica a un ensamblado concreto.Retrieves a custom attribute of a specified type that is applied to a specified assembly.

GetCustomAttributes(Assembly)

Recupera una colección de atributos personalizados que se aplican a un ensamblado especificado.Retrieves a collection of custom attributes that are applied to a specified assembly.

GetCustomAttributes(Assembly, Type)

Recupera una colección de atributos personalizados de un tipo especificado que se aplican a un ensamblado concreto.Retrieves a collection of custom attributes of a specified type that are applied to a specified assembly.

GetCustomAttributes<T>(Assembly)

Recupera una colección de atributos personalizados de un tipo especificado que se aplican a un ensamblado concreto.Retrieves a collection of custom attributes of a specified type that are applied to a specified assembly.

IsDefined(Assembly, Type)

Indica si se deben aplicar atributos personalizados de un tipo especificado a un ensamblado especificado.Indicates whether custom attributes of a specified type are applied to a specified assembly.

TryGetRawMetadata(Assembly, Byte*, Int32)

Se aplica a

Consulte también