System.AppDomain.DefineDynamicAssembly 方法 (AssemblyName, AssemblyBuilderAccess)
方法描述
以指定名称和访问模式定义动态程序集。
语法定义(C# System.AppDomain.DefineDynamicAssembly 方法 (AssemblyName, AssemblyBuilderAccess) 的用法)
public AssemblyBuilder DefineDynamicAssembly( AssemblyName name, AssemblyBuilderAccess access )
参数/返回值
参数值/返回值 | 参数类型/返回类型 | 参数描述/返回描述 |
---|---|---|
name | System-Reflection-AssemblyName | 动态程序集的唯一标识。 |
access | System-Reflection-Emit-AssemblyBuilderAccess | 动态程序集的访问模式。 |
返回值 | System.Reflection.Emit.AssemblyBuilder | 含指定名称和访问模式的动态程序集。 |
提示和注释
此方法只应用于在当前应用程序域中定义动态程序集。 有关更多信息,请参见 Load(AssemblyName) 方法重载。
注意
在开发用于发出动态程序集的代码过程中,建议您使用指定证据和权限的 DefineDynamicAssembly 方法重载,提供希望动态程序集所具有的证据以及在 refusedPermissions 中包括 SecurityPermissionFlag.SkipVerification。 在 refusedPermissions 参数中包括 SkipVerification 可以确保验证 MSIL。 这个技术的局限性在于,当与要求完全信任的代码一起使用时,它会导致引发 SecurityException。
System.AppDomain.DefineDynamicAssembly 方法 (AssemblyName, AssemblyBuilderAccess)例子
有关如何获取完全限定程序集名称的信息,请参见程序集名称。
using System; using System.Reflection; using System.Reflection.Emit; class Test { public static void Main() { AppDomain currentDomain = AppDomain.CurrentDomain; InstantiateMyDynamicType(currentDomain); // Failed! currentDomain.AssemblyResolve += new ResolveEventHandler(MyResolveEventHandler); InstantiateMyDynamicType(currentDomain); // OK! } static void InstantiateMyDynamicType(AppDomain domain) { try { // You must supply a valid fully qualified assembly name here. domain.CreateInstance("Assembly text name, Version, Culture, PublicKeyToken", "MyDynamicType"); } catch (Exception e) { Console.WriteLine(e.Message); } } static Assembly MyResolveEventHandler(object sender, ResolveEventArgs args) { return DefineDynamicAssembly((AppDomain) sender); } static Assembly DefineDynamicAssembly(AppDomain domain) { // Build a dynamic assembly using Reflection Emit API. AssemblyName assemblyName = new AssemblyName(); assemblyName.Name = "MyDynamicAssembly"; AssemblyBuilder assemblyBuilder = domain.DefineDynamicAssembly(assemblyName, AssemblyBuilderAccess.Run); ModuleBuilder moduleBuilder = assemblyBuilder.DefineDynamicModule("MyDynamicModule"); TypeBuilder typeBuilder = moduleBuilder.DefineType("MyDynamicType", TypeAttributes.Public); ConstructorBuilder constructorBuilder = typeBuilder.DefineConstructor(MethodAttributes.Public, CallingConventions.Standard, null); ILGenerator ilGenerator = constructorBuilder.GetILGenerator(); ilGenerator.EmitWriteLine("MyDynamicType instantiated!"); ilGenerator.Emit(OpCodes.Ret); typeBuilder.CreateType(); return assemblyBuilder; } }
异常
异常 | 异常描述 |
---|---|
ArgumentNullException | name 为 null。 |
ArgumentException |
|
AppDomainUnloadedException | 尝试对已卸载的应用程序域进行操作。 |
版本信息
.NET Framework 受以下版本支持:4、3.5、3.0、2.0、1.1、1.0 .NET Framework Client Profile 受以下版本支持:4、3.5 SP1
适用平台
Windows 7, Windows Vista SP1 或更高版本, Windows XP SP3, Windows XP SP2 x64 Edition, Windows Server 2008(不支持服务器核心), Windows Server 2008 R2(支持 SP1 或更高版本的服务器核心), Windows Server 2003 SP2 .NET Framework 并不是对每个平台的所有版本都提供支持。有关支持的版本的列表,请参见.NET Framework 系统要求。