将程序集加载到 AppDomain 中
本文关键字:AppDomain 加载 程序集 | 更新日期: 2023-09-27 18:32:07
>如果我使用
Assembly assembly = Assembly.LoadFrom(file);
后来尝试使用该文件,我得到一个异常,指出该文件正在使用中。
我需要将其加载到新的应用程序域上。
我似乎找到的只是如何在程序集中创建实例的示例,有没有办法加载整个程序集。
我需要的是:
(1) load the assembly into a new AppDomain from a file .
(2) extract an embedded resource (xml file) from the Dll .
(3) extract a type of class which implements an interface (which i know the interface type) .
(4) unload the entire appdomain in order to free the file .
2-4不是问题
我似乎找不到如何将程序集加载到新的AppDomin中,只有示例创建实例,这给了我一个来自 Dll 中的类的 instace。
我需要整个东西。
就像这个问题一样:创建实例的另一个例子。
将 DLL 加载到单独的应用程序域中
最基本的多域方案是
static void Main()
{
AppDomain newDomain = AppDomain.CreateDomain("New Domain");
newDomain.ExecuteAssembly("file.exe");
AppDomain.Unload(newDomain);
}
在单独的域上调用ExecuteAssembly
很方便,但不能提供与域本身交互的功能。它还要求目标程序集是可执行文件,并强制调用方到单个入口点。为了包含一些灵活性,您还可以将字符串或参数传递给.exe。
我希望这有所帮助。
扩展:然后尝试如下操作
AppDomainSetup setup = new AppDomainSetup();
setup.AppDomainInitializer = new AppDomainInitializer(ConfigureAppDomain);
setup.AppDomainInitializerArguments = new string[] { unknownAppPath };
AppDomain testDomain = AppDomain.CreateDomain("test", AppDomain.CurrentDomain.Evidence, setup);
AppDomain.Unload(testDomain);
File.Delete(unknownAppPath);
其中AppDomain
可以启动
public static void ConfigureAppDomain(string[] args)
{
string unknownAppPath = args[0];
AppDomain.CurrentDomain.DoCallBack(delegate()
{
//check that the new assembly is signed with the same public key
Assembly unknownAsm = AppDomain.CurrentDomain.Load(AssemblyName.GetAssemblyName(unknownAppPath));
//get the new assembly public key
byte[] unknownKeyBytes = unknownAsm.GetName().GetPublicKey();
string unknownKeyStr = BitConverter.ToString(unknownKeyBytes);
//get the current public key
Assembly asm = Assembly.GetExecutingAssembly();
AssemblyName aname = asm.GetName();
byte[] pubKey = aname.GetPublicKey();
string hexKeyStr = BitConverter.ToString(pubKey);
if (hexKeyStr == unknownKeyStr)
{
//keys match so execute a method
Type classType = unknownAsm.GetType("namespace.classname");
classType.InvokeMember("MethodNameToInvoke", BindingFlags.InvokeMethod, null, null, null);
}
});
}