完全に信頼できるasp.netmvc2アプリケーションのコンテキストで、2つの間に違いがあるかどうかを知りたいだけです。
1 に答える
.NET Framework は、アセンブリが必要になるまで、現在の AppDomain へのアセンブリの読み込みを延期します。たとえば、サード パーティのライブラリを からのみ呼び出した場合SomeMethod()
、サード パーティの DLL は通常、初回SomeMethod()
実行時までロードされません。
AppDomain.GetAssemblies()
現在の AppDomain に既に読み込まれているすべてのアセンブリを提供します。 BuildManager.GetReferencedAssemblies()
(このメソッドは.Net Framework System.Web.dll
でのみ使用できます) Web.config および他の場所から参照されるすべてのアセンブリのリストを返し、それらのアセンブリを現在の AppDomain に読み込みます。
上記を具体化した例です。
SomeMethod()
まだ実行していません。- を呼び出し
AppDomain.GetAssemblies()
、ThirdParty.dll を含まないセットを返します。 - コールし
SomeMethod()
ます。 - を呼び出し
AppDomain.GetAssemblies()
、ThirdParty.dll を含むセットを返します。
この例では、CLR は、絶対に必要になるまで、現在の AppDomain への ThirdParty.dll の読み込みを延期します。の実行に必要なのでSomeMethod()
、そのときにロードされます。
または:
SomeMethod()
まだ実行していません。- を呼び出し
AppDomain.GetAssemblies()
、ThirdParty.dll を含まないセットを返します。 - を呼び出し
BuildManager.GetReferencedAssemblies()
、ThirdParty.dll を含むセットを返します。 - を呼び出し
AppDomain.GetAssemblies()
、ThirdParty.dll を含むセットを返します。
ここでは、 を呼び出したことはありませんが、代わりにサードパーティ ライブラリを現在の AppDomain にロードするSomeMethod()
ための呼び出しです。BuildManager.GetReferencedAssemblies()
もちろん、これはすべて特定の最適化などの対象となりますが、一般的な考え方は当てはまります。