DLL のロード後に GetTypes() にかかる時間をテストするために、DLL のアンロードと再ロードのプロセスを調べてみましょう。 DLL.
アセンブリがAssembly.LoadFrom() を使用して読み込まれると、AppDomain のアセンブリのリストに追加されます。これをアンロードするには、Assembly または AppDomain にアンロードするための明示的なメソッドはありません。ただし、新しい AppDomain を作成してアセンブリをロードし、AppDomain をアンロードしてリソースを解放することはできます。
DLL をリロードするには、次の手順に従います。
string file = "path/to/assembly.dll"; // First AppDomain AppDomain dom1 = AppDomain.CreateDomain("domain1"); Assembly assem1 = dom1.Load(file); Stopwatch sw1 = Stopwatch.StartNew(); var types1 = assem1.GetTypes(); sw1.Stop(); double time1 = sw1.Elapsed.TotalMilliseconds; AppDomain.Unload(dom1); // Second AppDomain AppDomain dom2 = AppDomain.CreateDomain("domain2"); Assembly assem2 = dom2.Load(file); Stopwatch sw2 = Stopwatch.StartNew(); var types2 = assem2.GetTypes(); sw2.Stop(); double time2 = sw2.Elapsed.TotalMilliseconds; AppDomain.Unload(dom2); Console.WriteLine($"First Load: {time1} milliseconds"); Console.WriteLine($"Second Load: {time2} milliseconds");
この例では、2 つの AppDomain を作成し、DLL をロードします。 それぞれ。次に、両方のインスタンスの GetTypes() にかかる時間を測定します。タイミングの違いは、DLL の再ロードによって発生するオーバーヘッドを示している可能性があります。
assem = null では、アセンブリに割り当てられたリソースを解放するのに十分ではありません。 AppDomain 固有のリソースはガベージ コレクターによって管理されないため、ガベージ コレクターを明示的に呼び出しても役に立ちません。アセンブリをアンロードし、関連するリソースを解放するには、新しい AppDomain を使用することをお勧めします。
以上がAssembly.LoadFrom() でロードされたアセンブリを効率的にアンロードするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。