AppDomain.CreateComInstanceFrom Methode

Definition

Erstellt eine neue Instanz eines angegebenen COM-Typs.Creates a new instance of a specified COM type.

Überlädt

CreateComInstanceFrom(String, String)

Erstellt eine neue Instanz eines angegebenen COM-Typs.Creates a new instance of a specified COM type. Parameter geben den Namen einer Datei mit einer Assembly an, die den Typ und den Typnamen enthält.Parameters specify the name of a file that contains an assembly containing the type and the name of the type.

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

Erstellt eine neue Instanz eines angegebenen COM-Typs.Creates a new instance of a specified COM type. Parameter geben den Namen einer Datei mit einer Assembly an, die den Typ und den Typnamen enthält.Parameters specify the name of a file that contains an assembly containing the type and the name of the type.

CreateComInstanceFrom(String, String)

Erstellt eine neue Instanz eines angegebenen COM-Typs.Creates a new instance of a specified COM type. Parameter geben den Namen einer Datei mit einer Assembly an, die den Typ und den Typnamen enthält.Parameters specify the name of a file that contains an assembly containing the type and the name of the type.

public:
 System::Runtime::Remoting::ObjectHandle ^ CreateComInstanceFrom(System::String ^ assemblyName, System::String ^ typeName);
public System.Runtime.Remoting.ObjectHandle CreateComInstanceFrom (string assemblyName, string typeName);
member this.CreateComInstanceFrom : string * string -> System.Runtime.Remoting.ObjectHandle
Public Function CreateComInstanceFrom (assemblyName As String, typeName As String) As ObjectHandle

Parameter

assemblyName
String

Der Name einer Datei, die eine Assembly enthält, in der der angeforderte Typ definiert ist.The name of a file containing an assembly that defines the requested type.

typeName
String

Der Name des angeforderten Typs.The name of the requested type.

Gibt zurück

Ein Objekt, das ein Wrapper für die neue Instanz ist, die durch typeName angegeben wird.An object that is a wrapper for the new instance specified by typeName. Der Rückgabewert muss für den Zugriff auf das eigentliche Objekt entwrappt werden.The return value needs to be unwrapped to access the real object.

Ausnahmen

assemblyName oder typeName ist null.assemblyName or typeName is null.

Der Typ kann nicht geladen werden.The type cannot be loaded.

Der Vorgang wird für eine entladene Anwendungsdomäne ausgeführt.The operation is attempted on an unloaded application domain.

Es wurde kein öffentlicher parameterloser Konstruktor gefunden.No public parameterless constructor was found.

assemblyName wurde nicht gefunden.assemblyName is not found.

typeName ist eine abstrakte Klasse.typeName is an abstract class.

- oder --or- Dieser Member wurde durch einen Mechanismus mit später Bindung aufgerufen.This member was invoked with a late-binding mechanism.

Der Aufrufer kann keine Aktivierungsattribute für ein Objekt bereitstellen, das nicht von MarshalByRefObject erbt.The caller cannot provide activation attributes for an object that does not inherit from MarshalByRefObject.

assemblyName ist eine leere Zeichenfolge ("").assemblyName is an empty string ("").

assemblyName ist keine gültige Assembly.assemblyName is not a valid assembly.

Eine Assembly oder ein Modul wurde zweimal mit zwei unterschiedlichen Beweisen geladen.An assembly or module was loaded twice with two different evidences.

Das COM-Objekt, auf das verwiesen wird, ist null.The COM object that is being referred to is null.

Beispiele

Im folgenden Beispiel wird veranschaulicht.The following sample demonstrates

using namespace System;
using namespace System::Reflection;
using namespace System::Runtime::InteropServices;

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

};


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

};

void CreateComInstance( String^ typeName )
{
   try
   {
      AppDomain^ currentDomain = AppDomain::CurrentDomain;
      String^ assemblyName = currentDomain->FriendlyName;
      currentDomain->CreateComInstanceFrom( assemblyName, typeName );
   }
   catch ( Exception^ e ) 
   {
      Console::WriteLine( e->Message );
   }

}

int main()
{
   CreateComInstance( "MyComNonVisibleType" ); // Fail!
   CreateComInstance( "MyComVisibleType" ); // OK!
}

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 Test {
   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);
      }
   }
}
Imports System.Reflection
Imports System.Runtime.InteropServices

<ComVisible(True)> _
Class MyComVisibleType

   Public Sub New()
      Console.WriteLine("MyComVisibleType instantiated!")
   End Sub

End Class

<ComVisible(False)> _
Class MyComNonVisibleType

   Public Sub New()
      Console.WriteLine("MyComNonVisibleType instantiated!")
   End Sub

End Class

Module Test

   Sub Main()
      CreateComInstance("MyComNonVisibleType")   ' Fail!
      CreateComInstance("MyComVisibleType")      ' OK!
   End Sub

   Sub CreateComInstance(typeName As String)
      Try
         Dim currentDomain As AppDomain = AppDomain.CurrentDomain
         Dim assemblyName As String = currentDomain.FriendlyName
         currentDomain.CreateComInstanceFrom(assemblyName, typeName)
      Catch e As Exception
         Console.WriteLine(e.Message)
      End Try
   End Sub

End Module 'Test

Hinweise

Verwenden Sie diese Methode, um Objekte Remote zu erstellen, ohne den Typ lokal laden zu müssen.Use this method to create objects remotely without having to load the type locally.

Der Rückgabewert muss für den Zugriff auf das echte Objekt entpackt werden.The return value must to be unwrapped to access the real object.

Ein System.Runtime.InteropServices.ComVisibleAttribute Attribut mit dem Wert true muss entweder explizit oder standardmäßig auf den com-Typ angewendet werden, damit diese Methode eine Instanz dieses Typs erstellt. Andernfalls wird TypeLoadException ausgelöst.A System.Runtime.InteropServices.ComVisibleAttribute attribute with a value of true must be applied either explicitly or by default to the COM type for this method to create an instance of that type; otherwise, TypeLoadException is thrown.

Siehe auch

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

Erstellt eine neue Instanz eines angegebenen COM-Typs.Creates a new instance of a specified COM type. Parameter geben den Namen einer Datei mit einer Assembly an, die den Typ und den Typnamen enthält.Parameters specify the name of a file that contains an assembly containing the type and the name of the type.

public:
 System::Runtime::Remoting::ObjectHandle ^ CreateComInstanceFrom(System::String ^ assemblyFile, System::String ^ typeName, cli::array <System::Byte> ^ hashValue, System::Configuration::Assemblies::AssemblyHashAlgorithm hashAlgorithm);
public System.Runtime.Remoting.ObjectHandle CreateComInstanceFrom (string assemblyFile, string typeName, byte[] hashValue, System.Configuration.Assemblies.AssemblyHashAlgorithm hashAlgorithm);
member this.CreateComInstanceFrom : string * string * byte[] * System.Configuration.Assemblies.AssemblyHashAlgorithm -> System.Runtime.Remoting.ObjectHandle
Public Function CreateComInstanceFrom (assemblyFile As String, typeName As String, hashValue As Byte(), hashAlgorithm As AssemblyHashAlgorithm) As ObjectHandle

Parameter

assemblyFile
String

Der Name einer Datei, die eine Assembly enthält, in der der angeforderte Typ definiert ist.The name of a file containing an assembly that defines the requested type.

typeName
String

Der Name des angeforderten Typs.The name of the requested type.

hashValue
Byte[]

Stellt den Wert des errechneten Hashcodes dar.Represents the value of the computed hash code.

hashAlgorithm
AssemblyHashAlgorithm

Stellt den vom Assemblymanifest verwendeten Hashalgorithmus dar.Represents the hash algorithm used by the assembly manifest.

Gibt zurück

Ein Objekt, das ein Wrapper für die neue Instanz ist, die durch typeName angegeben wird.An object that is a wrapper for the new instance specified by typeName. Der Rückgabewert muss für den Zugriff auf das eigentliche Objekt entwrappt werden.The return value needs to be unwrapped to access the real object.

Ausnahmen

assemblyName oder typeName ist null.assemblyName or typeName is null.

Der Typ kann nicht geladen werden.The type cannot be loaded.

Der Vorgang wird für eine entladene Anwendungsdomäne ausgeführt.The operation is attempted on an unloaded application domain.

Es wurde kein öffentlicher parameterloser Konstruktor gefunden.No public parameterless constructor was found.

assemblyFile wurde nicht gefunden.assemblyFile is not found.

typeName ist eine abstrakte Klasse.typeName is an abstract class.

- oder --or- Dieser Member wurde durch einen Mechanismus mit später Bindung aufgerufen.This member was invoked with a late-binding mechanism.

Der Aufrufer kann keine Aktivierungsattribute für ein Objekt bereitstellen, das nicht von MarshalByRefObject erbt.The caller cannot provide activation attributes for an object that does not inherit from MarshalByRefObject.

assemblyFile ist die leere Zeichenfolge („“).assemblyFile is the empty string ("").

assemblyFile ist keine gültige Assembly.assemblyFile is not a valid assembly.

Eine Assembly oder ein Modul wurde zweimal mit zwei unterschiedlichen Beweisen geladen.An assembly or module was loaded twice with two different evidences.

Das COM-Objekt, auf das verwiesen wird, ist null.The COM object that is being referred to is null.

Hinweise

Verwenden Sie diese Methode, um Objekte Remote zu erstellen, ohne den Typ lokal laden zu müssen.Use this method to create objects remotely without having to load the type locally.

Der Rückgabewert muss für den Zugriff auf das echte Objekt entpackt werden.The return value must to be unwrapped to access the real object.

Ein System.Runtime.InteropServices.ComVisibleAttribute Attribut mit dem Wert true muss entweder explizit oder standardmäßig auf den com-Typ angewendet werden, damit diese Methode eine Instanz dieses Typs erstellt. Andernfalls wird TypeLoadException ausgelöst.A System.Runtime.InteropServices.ComVisibleAttribute attribute with a value of true must be applied either explicitly or by default to the COM type for this method to create an instance of that type; otherwise, TypeLoadException is thrown.

Siehe auch

Gilt für: