Auf Englisch lesen

Teilen über


AppDomain.CreateComInstanceFrom Methode

Definition

Erstellt eine neue Instanz eines angegebenen COM-Typs.

Überlädt

CreateComInstanceFrom(String, String)

Erstellt eine neue Instanz eines angegebenen COM-Typs. Parameter geben den Namen einer Datei an, die eine Assembly enthält, die den Typ und den Namen des Typs enthält.

CreateComInstanceFrom(String, String, Byte[], AssemblyHashAlgorithm)

Erstellt eine neue Instanz eines angegebenen COM-Typs. Parameter geben den Namen einer Datei an, die eine Assembly enthält, die den Typ und den Namen des Typs enthält.

CreateComInstanceFrom(String, String)

Erstellt eine neue Instanz eines angegebenen COM-Typs. Parameter geben den Namen einer Datei an, die eine Assembly enthält, die den Typ und den Namen des Typs enthält.

C#
public System.Runtime.Remoting.ObjectHandle CreateComInstanceFrom(string assemblyName, string typeName);

Parameter

assemblyName
String

Der Name einer Datei mit einer Assembly, die den angeforderten Typ definiert.

typeName
String

Der Name des angeforderten Typs.

Gibt zurück

Ein Objekt, das ein Wrapper für die neue Instanz ist, die durch typeNameangegeben wird. Der Rückgabewert muss entwrappt werden, um auf das reale Objekt zuzugreifen.

Ausnahmen

assemblyName oder typeName ist null.

Der Typ kann nicht geladen werden.

Der Vorgang wird in einer nicht geladenen Anwendungsdomäne versucht.

Es wurde kein öffentlicher parameterloser Konstruktor gefunden.

assemblyName wurde nicht gefunden.

typeName ist eine abstrakte Klasse.

-oder-

Dieses Element wurde mit einem Spätbindungsmechanismus aufgerufen.

Der Aufrufer kann keine Aktivierungsattribute für ein Objekt bereitstellen, das nicht von MarshalByRefObjecterbt.

assemblyName ist eine leere Zeichenfolge ("").

assemblyName ist keine gültige Assembly.

Eine Assembly oder ein Modul wurde zweimal mit zwei verschiedenen Nachweisen geladen.

Das COM-Objekt, auf das verwiesen wird, ist null.

Beispiele

Das folgende Beispiel veranschaulicht

C#
using System;
using System.Reflection;
using System.Runtime.InteropServices;

[ComVisible(true)]
class MyComVisibleType {
   public MyComVisibleType() {
      Console.WriteLine("MyComVisibleType instantiated!");
   }
}

[ComVisible(false)]
class MyComNonVisibleType {
   public MyComNonVisibleType() {
      Console.WriteLine("MyComNonVisibleType instantiated!");
   }
}

class CreateComInstanceFromSnippet {
   public static void Main() {
      CreateComInstance("MyComNonVisibleType");   // Fail!
      CreateComInstance("MyComVisibleType");      // OK!
   }

   static void CreateComInstance(string typeName) {
      try {
         AppDomain currentDomain = AppDomain.CurrentDomain;
         string assemblyName = currentDomain.FriendlyName;
         currentDomain.CreateComInstanceFrom(assemblyName, typeName);
      } catch (Exception e) {
         Console.WriteLine(e.Message);
      }
   }
}

Hinweise

Verwenden Sie diese Methode, um Objekte remote zu erstellen, ohne den Typ lokal laden zu müssen.

Der Rückgabewert muss aufgehoben werden, um auf das reale Objekt zuzugreifen.

Ein System.Runtime.InteropServices.ComVisibleAttribute-Attribut mit dem Wert true muss entweder explizit oder standardmäßig auf den COM-Typ für diese Methode angewendet werden, um eine Instanz dieses Typs zu erstellen; andernfalls wird TypeLoadException ausgelöst.

Weitere Informationen

Gilt für:

.NET Framework 4.8.1 und andere Versionen
Produkt Versionen
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1

CreateComInstanceFrom(String, String, Byte[], AssemblyHashAlgorithm)

Erstellt eine neue Instanz eines angegebenen COM-Typs. Parameter geben den Namen einer Datei an, die eine Assembly enthält, die den Typ und den Namen des Typs enthält.

C#
public System.Runtime.Remoting.ObjectHandle CreateComInstanceFrom(string assemblyFile, string typeName, byte[] hashValue, System.Configuration.Assemblies.AssemblyHashAlgorithm hashAlgorithm);

Parameter

assemblyFile
String

Der Name einer Datei mit einer Assembly, die den angeforderten Typ definiert.

typeName
String

Der Name des angeforderten Typs.

hashValue
Byte[]

Stellt den Wert des berechneten Hashcodes dar.

hashAlgorithm
AssemblyHashAlgorithm

Stellt den vom Assemblymanifest verwendeten Hashalgorithmus dar.

Gibt zurück

Ein Objekt, das ein Wrapper für die neue Instanz ist, die durch typeNameangegeben wird. Der Rückgabewert muss entwrappt werden, um auf das reale Objekt zuzugreifen.

Ausnahmen

assemblyFile oder typeName ist null.

Der Typ kann nicht geladen werden.

Der Vorgang wird in einer nicht geladenen Anwendungsdomäne versucht.

Es wurde kein öffentlicher parameterloser Konstruktor gefunden.

assemblyFile wurde nicht gefunden.

typeName ist eine abstrakte Klasse.

-oder-

Dieses Element wurde mit einem Spätbindungsmechanismus aufgerufen.

Der Aufrufer kann keine Aktivierungsattribute für ein Objekt bereitstellen, das nicht von MarshalByRefObjecterbt.

assemblyFile ist die leere Zeichenfolge ("").

assemblyFile ist keine gültige Assembly.

Eine Assembly oder ein Modul wurde zweimal mit zwei verschiedenen Nachweisen geladen.

Das COM-Objekt, auf das verwiesen wird, ist null.

Hinweise

Verwenden Sie diese Methode, um Objekte remote zu erstellen, ohne den Typ lokal laden zu müssen.

Der Rückgabewert muss aufgehoben werden, um auf das reale Objekt zuzugreifen.

Ein System.Runtime.InteropServices.ComVisibleAttribute-Attribut mit dem Wert true muss entweder explizit oder standardmäßig auf den COM-Typ für diese Methode angewendet werden, um eine Instanz dieses Typs zu erstellen; andernfalls wird TypeLoadException ausgelöst.

Weitere Informationen

Gilt für:

.NET Framework 4.8.1 und andere Versionen
Produkt Versionen
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1