真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

.NETCore3.0可回收程序集加載上下文怎么實(shí)現(xiàn)

這篇文章主要講解了“.NET Core 3.0可回收程序集加載上下文怎么實(shí)現(xiàn)”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“.NET Core 3.0可回收程序集加載上下文怎么實(shí)現(xiàn)”吧!

創(chuàng)新互聯(lián)公司專注于西充網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗(yàn)。 熱誠為您提供西充營銷型網(wǎng)站建設(shè),西充網(wǎng)站制作、西充網(wǎng)頁設(shè)計(jì)、西充網(wǎng)站官網(wǎng)定制、微信小程序開發(fā)服務(wù),打造西充網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供西充網(wǎng)站排名全網(wǎng)營銷落地服務(wù)。

一、前世今生

.NET誕生以來,程序集的動態(tài)加載和卸載都是一個Hack的技術(shù),之前的NetFx都是使用AppDomain的方式去加載程序集,然而AppDomain并沒有提供直接卸載一個程序集的API,而是要卸載整個AppDomain才能卸載包含在其中的所有程序集。然而卸載整個CurrentAppDomain會使程序不能工作。可能有人另辟西經(jīng),創(chuàng)建別一個AppDomain來加載/卸載程序集,但是由于程序集之間是不能跨域訪問的,也導(dǎo)致只能通過Remote Proxy的方式去訪問,這樣在類型創(chuàng)建和使用上帶來了一定的難度也是類型的繼承變得相當(dāng)復(fù)雜。

.NET Core中一直沒有AppDomain的支持。但是在.NET Core 3.0中,我最期待的一個特性就是對可收集程序集的支持(Collectible AssemblyLoadContext)。眾所周知.NET Core中一直使用AssemblyLoadContext的API,來進(jìn)行程序集的動態(tài)加載,但是并沒有提供Unload的方法,此次升級更新了這方面的能力。

二、AssemblyLoadContext

其實(shí)這次AssemblyLoadContext的設(shè)計(jì),我認(rèn)為更像是Java中ClassLoader的翻版,可以說非常類似。在使用過程中自定義AssemblyLoadContext可以內(nèi)部管理其中的程序集,并對整體Context進(jìn)行Unload。使用AssemblyLoadContext也可以避免程序集名稱和版本的沖突。

三、Getting Started

.NET Core 3.0還沒有正式版,所有要使用預(yù)覽版的SDK完成以下實(shí)例。我使用的是.NET Core SDK 3.0.100-preview-009812

dotnet new globaljson --sdk-version 3.0.100-preview-009812

AssemblyLoadContext是一個抽象類的,我們需要子類化。下面顯示的是我們創(chuàng)建自定義AssemblyLoadContext的方法,實(shí)現(xiàn)一個可回收的Context需要在構(gòu)造器中指定isCollectible: true :

public class CollectibleAssemblyLoadContext : AssemblyLoadContext{    public CollectibleAssemblyLoadContext() : base(isCollectible: true)       { }     protected override Assembly Load(AssemblyName assemblyName)       {             return null;    }}

使用netstandard2.0創(chuàng)建一個library

using System; namespace SampleLibrary{    public class SayHello    {            public void Hello(int iteration)             {            Console.WriteLine($"Hello {iteration}!");        }    }}

測試Load/Unload


var context = new CollectibleAssemblyLoadContext();var assemblyPath = Path.Combine(Directory.GetCurrentDirectory(),"SampleLibrary.dll");using (var fs = new FileStream(assemblyPath, FileMode.Open, FileAccess.Read)){    var assembly = context.LoadFromStream(fs);
   var type = assembly.GetType("SampleLibrary.SayHello");    var greetMethod = type.GetMethod("Hello");
   var instance = Activator.CreateInstance(type);    greetMethod.Invoke(instance, new object[] { i });}
context.Unload();
GC.Collect();GC.WaitForPendingFinalizers();

當(dāng)執(zhí)行GC收回后,加載的程序集會被完全的回收。

感謝各位的閱讀,以上就是“.NET Core 3.0可回收程序集加載上下文怎么實(shí)現(xiàn)”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對.NET Core 3.0可回收程序集加載上下文怎么實(shí)現(xiàn)這一問題有了更深刻的體會,具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識點(diǎn)的文章,歡迎關(guān)注!


本文名稱:.NETCore3.0可回收程序集加載上下文怎么實(shí)現(xiàn)
文章位置:http://weahome.cn/article/pishse.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部