Freigeben über


Vorgehensweise: Konfigurieren einer Anwendungsdomäne

Hinweis

Dieser Artikel ist spezifisch für .NET Framework. Sie gilt nicht für neuere Implementierungen von .NET, einschließlich .NET 6 und höherer Versionen.

Sie können die Common Language Runtime mit Konfigurationsinformationen für eine neue Anwendungsdomäne mithilfe der AppDomainSetup Klasse bereitstellen. Beim Erstellen eigener Anwendungsdomänen ist ApplicationBasedie wichtigste Eigenschaft . Die anderen AppDomainSetup Eigenschaften werden hauptsächlich von Laufzeithosts verwendet, um eine bestimmte Anwendungsdomäne zu konfigurieren.

Die ApplicationBase Eigenschaft definiert das Stammverzeichnis der Anwendung. Wenn die Laufzeit eine Typanforderung erfüllen muss, sucht sie nach der Assembly, die den Typ im durch die Eigenschaft ApplicationBase dargestellten Verzeichnis enthält.

Hinweis

Eine neue Anwendungsdomäne erbt nur die ApplicationBase Eigenschaft des Erstellers.

Im folgenden Beispiel wird eine Instanz der AppDomainSetup Klasse erstellt, diese Klasse verwendet, um eine neue Anwendungsdomäne zu erstellen, die Informationen in die Konsole zu schreiben und dann die Anwendungsdomäne entladen.

Example

using namespace System;
using namespace System::Reflection;

ref class AppDomain4
{
public:
    static void Main()
    {
        // Create application domain setup information.
        AppDomainSetup^ domaininfo = gcnew AppDomainSetup();
        domaininfo->ApplicationBase = "f:\\work\\development\\latest";

        // Create the application domain.
        AppDomain^ domain = AppDomain::CreateDomain("MyDomain", nullptr, domaininfo);

        // Write application domain information to the console.
        Console::WriteLine("Host domain: " + AppDomain::CurrentDomain->FriendlyName);
        Console::WriteLine("child domain: " + domain->FriendlyName);
        Console::WriteLine("Application base is: " + domain->SetupInformation->ApplicationBase);

        // Unload the application domain.
        AppDomain::Unload(domain);
    }
};

int main()
{
    AppDomain4::Main();
}
using System;
using System.Reflection;

class AppDomain4
{
    public static void Main()
    {
        // Create application domain setup information.
        AppDomainSetup domaininfo = new AppDomainSetup();
        domaininfo.ApplicationBase = "f:\\work\\development\\latest";

        // Create the application domain.
        AppDomain domain = AppDomain.CreateDomain("MyDomain", null, domaininfo);

        // Write application domain information to the console.
        Console.WriteLine("Host domain: " + AppDomain.CurrentDomain.FriendlyName);
        Console.WriteLine("child domain: " + domain.FriendlyName);
        Console.WriteLine("Application base is: " + domain.SetupInformation.ApplicationBase);

        // Unload the application domain.
        AppDomain.Unload(domain);
    }
}
Imports System.Reflection

Class AppDomain4
    Public Shared Sub Main()
        ' Create application domain setup information.
        Dim domaininfo As new AppDomainSetup()
        domaininfo.ApplicationBase = "f:\work\development\latest"

        ' Create the application domain.
        Dim domain As AppDomain = AppDomain.CreateDomain("MyDomain", Nothing, domaininfo)

        ' Write application domain information to the console.
        Console.WriteLine("Host domain: " + AppDomain.CurrentDomain.FriendlyName)
        Console.WriteLine("child domain: " + domain.FriendlyName)
        Console.WriteLine("Application base is: " + domain.SetupInformation.ApplicationBase)

        ' Unload the application domain.
        AppDomain.Unload(domain)
    End Sub
End Class

Siehe auch