.Net6新版本的AssemblyLoadContext 加载程序集和卸载程序集


.Net6新版本的AssemblyLoadContext 加载程序集和卸载程序集

文章插图
准备俩个项目
第一个是控制台
第二个项目是类库
类库项目中只有一个示例class
将类库的代码生成dll
.Net6新版本的AssemblyLoadContext 加载程序集和卸载程序集

文章插图
并且设置属性为复制到输出目录

using System.Runtime.Loader;

【.Net6新版本的AssemblyLoadContext 加载程序集和卸载程序集】var domain = new AssemblyLoadContext("DomainServer", true);

var assembly = domain.LoadFromAssemblyPath(Path.Combine(AppContext.BaseDirectory, "DomainServer.dll"));

foreach (var context in AssemblyLoadContext.All){    Console.WriteLine("当前存在的程序集:"+context.Name);}

Console.WriteLine("-------------------------");

domain.Unload();

foreach (var context in AssemblyLoadContext.All){    Console.WriteLine("当前存在的程序集:" + context.Name);}

Console.ReadKey();
 
写入代码到Program类中  由于项目使用.net7创建 所以采用顶级语法 没有main方法
然后执行程序
.Net6新版本的AssemblyLoadContext 加载程序集和卸载程序集

文章插图
我们看到当加载程序的时候我们的项目中存在了俩个程序集
当前Unload卸载程序集的时候我们项目只存在一个程序集
使用 new AssemblyLoadContext("DomainServer", true); 创建一个AssemblyLoadContext对象
第二个参数 true启用卸载;否则,假的 。默认值为false,因为启用卸载会带来性能损失 。
这个卸载只会卸载AssemblyLoadContext中加载的所有程序集
我们还可以订阅卸载事件这样就知道那些程序集卸载成功了
using System.Runtime.Loader;var domain = new AssemblyLoadContext("DomainServer",true);var assembly = domain.LoadFromAssemblyPath(Path.Combine(AppContext.BaseDirectory, "DomainServer.dll"));foreach (var context in AssemblyLoadContext.All){    Console.WriteLine("当前存在的程序集:"+context.Name);}Console.WriteLine("-------------------------");domain.Unloading += context =>{    Console.WriteLine("当前卸载的程序集:"+string.Join(',', context.Assemblies.Select(x => x.FullName)));};domain.Unload();foreach (var context in AssemblyLoadContext.All){    Console.WriteLine("当前存在的程序集:" + context.Name);}Console.ReadKey();执行效果:
.Net6新版本的AssemblyLoadContext 加载程序集和卸载程序集

文章插图
好了介绍到这里!

    推荐阅读